每日一道算法题 10(2023-12-18)

题目描述:

单词接龙的规则是:

可用于接龙的单词首字母必须要与前一个单词的尾字母相同;

当存在多个首字母相同的单词时,取长度最长的单词,如果长度也相等,则取字典序最小的单词;已经参与接龙的单词不能重复使用。

现给定一组全部由小写字母组成单词数组,并指定其中的一个单词作为起始单词,进行单词接龙,

请输出最长的单词串,单词串是单词拼接而成,中间没有空格

输入描述:

输入的第一行为一个非负整数,表示起始单词在数组中的索引K,0 <= K < N ;

输入的第二行为一个非负整数,表示单词的个数N;

接下来的N行,分别表示单词数组中的单词。

备注:

单词个数N的取值范围为[1, 20];

单个单词的长度的取值范围为[1, 30];

输出描述

输出一个字符串,表示最终拼接的单词串。

示例1

输入

0

6

word

dd

da

dc

dword

d

输出

worddwordda

说明

先确定起始单词word,再接以d开头的且长度最长的单词dword,剩余以d开头且长度最长的有dd、da、dc,则取字典序最小的da,所以最后输出worddwordda。

示例2

输入

4

6

word

dd

da

dc

dword

d

输出

dwordda

说明

先确定起始单词dword,剩余以d开头且长度最长的有dd、da、dc,则取字典序最小的da,所以最后输出dwordda。

package com.tarena.test.B10;import java.util.ArrayList;

import java.util.HashMap;

import java.util.LinkedList;

import java.util.Scanner;

/**

* @author Administrator

*

*/

public class B19 {

public static void main(String[] args) {

try (Scanner sc = new Scanner(System.in)) {

int k = sc.nextInt();

int n = sc.nextInt();

String[] words = new String[n];

for(int i=0;i<n;i++) words[i]=sc.next();

System.out.println(getResult(k,n,words));

}

}

public static String getResult(int k,int n,String[] words) {

ArrayList<String> chain = new ArrayList<>();

chain.add(words[k]);

words[k] = null;

HashMap<Character,LinkedList<String>> prefix = new HashMap<>();

for(String word : words) {

if(null != word) {

char c = word.charAt(0);

prefix.putIfAbsent(c, new LinkedList<>());

prefix.get(c).add(word);

}

}

for(Character c:prefix.keySet()) {

prefix

.get(c)

.sort((a,b)->a.length() != b.length() ? b.length() - a.length() : a.compareTo(b) );

}

while(true) {

String tail = chain.get(chain.size()-1);

char c = tail.charAt(tail.length()-1);

if(prefix.containsKey(c)) {

chain.add(prefix.get(c).removeFirst());

}else {

break;

}

}

StringBuilder sb = new StringBuilder();

for(String str:chain) sb.append(str);

return sb.toString();

}

}

了解知识点

1、HashMap putIfAbsent 方法的使用,之前都是自己写判断逻辑,get 判空,new List 刚发现有现成的

2、 List sort 方法的使用

相关推荐
刚学HTML26 分钟前
leetcode 05 回文字符串
算法·leetcode
Yan.love39 分钟前
开发场景中Java 集合的最佳选择
java·数据结构·链表
椰椰椰耶42 分钟前
【文档搜索引擎】搜索模块的完整实现
java·搜索引擎
大G哥42 分钟前
java提高正则处理效率
java·开发语言
AC使者1 小时前
#B1630. 数字走向4
算法
冠位观测者1 小时前
【Leetcode 每日一题】2545. 根据第 K 场考试的分数排序
数据结构·算法·leetcode
智慧老师1 小时前
Spring基础分析13-Spring Security框架
java·后端·spring
lxyzcm1 小时前
C++23新特性解析:[[assume]]属性
java·c++·spring boot·c++23
古希腊掌管学习的神2 小时前
[搜广推]王树森推荐系统笔记——曝光过滤 & Bloom Filter
算法·推荐算法
qystca2 小时前
洛谷 P1706 全排列问题 C语言
算法