目录
题目描述
输入描述
输出描述
用例
题目解析
算法源码
单词接龙的规则是:
备注:
| 输入 | 0 6 word dd da dc dword d |
| 输出 | worddwordda |
| 说明 | 先确定起始单词word,再接以d开头的且长度最长的单词dword,剩余以d开头且长度最长的有dd、da、dc,则取字典序最小的da,所以最后输出worddwordda。 |
| 输入 | 4 6 word dd da dc dword d |
| 输出 | dwordda |
| 说明 | 先确定起始单词dword,剩余以d开头且长度最长的有dd、da、dc,则取字典序最小的da,所以最后输出dwordda。 |
逻辑题,主要考察数组操作,如数组元素删除,数组自定义排序。
我的解题思路如下:
先用splice方法,将起始单词从输入数组中删除,splice会将删除的元素形成一个新数组,我刚好将该数组作为收集接龙单词的链条数组chain。
之后,遍历输入数组中剩下的单词,将它们根据首字母进行分类,同一个首字母的单词存放在一个数组中。存储容器选择对象prefix,首字母作为对象的属性,存放同首单词的数组为对象的属性值。
当统计完后,对每个分类数组进行排序,即优先按照单词长度降序,如果单词长度相同,再按照字典序升序。
之后,取出chain的尾巴元素,再取出尾巴元素单词的尾巴字符tail,如果存在prefix[tail],则取出prefix[tail]数组的头部元素加入chain中,然后继续循环前面逻辑,如果不存在prefix[tail],则结束循环,将chain.join('') 当成结果输出。
/* JavaScript Node ACM模式 控制台输入获取 */
const readline = require("readline");const rl = readline.createInterface({input: process.stdin,output: process.stdout,
});const lines = [];
let k, n;
rl.on("line", (line) => {lines.push(line);if (lines.length === 2) {[k, n] = lines.map(Number);}if (n && lines.length === n + 2) {const words = lines.slice(2);console.log(wordChain(words, k));lines.length = 0;}
});function wordChain(words, k) {const chain = words.splice(k, 1);const prefix = {};words.forEach((word) => {const w = word[0];prefix[w] ? prefix[w].push(word) : (prefix[w] = [word]);});for (let key in prefix) {prefix[key].sort((a, b) =>a.length === b.length ? (a > b ? 1 : -1) : b.length - a.length);}while (true) {let tail = chain.at(-1).at(-1);if (prefix[tail]) {chain.push(prefix[tail].shift());} else {break;}}return chain.join("");
}