当前位置: 首页 > news >正文

考古学家 - 华为OD统一考试(JavaScript 题解)

alt

题目描述

有一个考古学家发现一个石碑,但是很可惜发现时其已经断成多段。

原地发现N个断口整齐的石碑碎片,为了破解石碑内容,考古学家希望有程序能帮忙计算复原后的石碑文字组合数,你能帮忙吗?

备注: 如果存在石碑碎片内容完全相同,则由于碎片间的顺序不影响复原后的碑文内容,仅相同碎片间的位置变化不影响组合

输入描述

第一行输入NN表示石碑碎片的个数

第二行依次输入石碑碎片上的文字内容S共有N

输出描述

输出石碑文字的组合(按照升序排列),行尾无多余空格

示例1

输入:
3
a b c输出:
abc
acb
bac
bca
cab
cba

示例2

输入:
3
a b a输出:
aab
aba
baa

示例3

输入:
3
a b ab输出:
aabb
abab
abba
baab
baba

题解

这是一个典型的排列组合问题,可以使用回溯算法来生成所有可能的组合。

代码大致描述:

  1. 读取石碑碎片的个数n和每个碎片的文字内容ss。
  2. 创建一个用于标记是否使用过的数组used和一个用于存储当前组合的容器collect,以及 rs 存储结果。
  3. 调用backtrack函数进行回溯,生成所有可能的排列组合。
  4. backtrack函数中,检查当前组合的长度是否等于石碑碎片的个数n,如果是则拼接成字符串并存入 rs 中。
  5. 递归调用backtrack函数,尝试不同的组合。
  6. 在每次递归调用前,标记当前石碑碎片为已使用,以防止重复使用。
  7. 递归调用后,将标记恢复,进行下一轮尝试。

这样,通过回溯算法,可以遍历所有可能的排列组合,最终可以生成所有的石碑文字组合,然后排序输出。

JavaScript

const rl = require('readline').createInterface({input: process.stdin,
});
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;// Author: code5bug
void (async function () {// 读取输入const n = parseInt(await readline());const ss = (await readline()).split(' ');// 初始化变量const used = new Array(n).fill(false); // 标记元素是否被使用const collect = []; // 当前收集的组合const rs = new Set(); // 存储所有不重复的组合结果// 回溯函数function backtrack() {if (collect.length === n) {// 组合完成rs.add(collect.join(''));return;}for (let i = 0; i < n; i++) {// 元素被使用或与前一个相同则跳过if (used[i] || (i > 0 && ss[i - 1] === ss[i])) continue;used[i] = true;collect.push(ss[i]);backtrack(); // 递归collect.pop();used[i] = false;}}backtrack(); // 开始回溯// 输出结果,按字典序排序console.log([...rs].sort().join('\n'));rl.close();
})();

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

http://www.dtcms.com/a/304192.html

相关文章:

  • npm : 无法加载文件 D:\Nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本
  • 复现cacti的RCE(CVE-2022-46169)
  • EM储能网关ZWS智慧储能云应用(17) — 动环监控
  • 鲸鱼小说分销系统v1.0.0公测版更新发布-完成了小说整体基础以及完整分销和数据看板
  • 应广MTP单片机在线烧录技巧
  • 嵌入式学习日志————TIM定时中断之定时器定时中断
  • git使用lfs解决大文件上传限制
  • 【PHP】Swoole:CentOS安装Composer+Hyperf
  • 【C++算法】76.优先级队列_前 K 个高频单词
  • 引领新一代 Web3 金融类应用开发,全景式探析 Injective 生态
  • 乳腺癌病理知识
  • 网络安全的变革:深入洞察 Web3 与传统网络模型
  • 黑客哲学之学习笔记系列(一)
  • 随机森林算法原理及优缺点
  • 华为光学设计面试题
  • 频谱周期性复制
  • 数据库管理-第352期 从需求看懂Oracle RAC多租户环境的Service(20250729)
  • C++ 1.面向对象编程(OOP)框架
  • SBB指令的“生活小剧场“
  • Excel工作簿合并工具,快速查找一键整合
  • 「源力觉醒 创作者计划」_DeepseekVS文心一言
  • JavaWeb 入门:CSS 基础与实战详解(Java 开发者视角)
  • 查询mac 安装所有python 版本
  • 服务器之光:Nginx--反向代理模块详解及演练
  • PHP性能优化与高并发处理:从基础到高级实践
  • Rust 实战三 | HTTP 服务开发及 Web 框架推荐
  • AI 数字人在处理音频时,如何确保声音的自然度?
  • 使用 Canvas 替代 <video> 标签加载并渲染视频
  • Vue 2.0响应式原理深度解析
  • 艾体宝方案 | 数据孤岛终结者:GWI + DOMO 联手打造一体化增长引擎