一、题目描述
给定一个可存储若干单词的字典,找出指定单词的所有相似单词,并且按照单词名称从小到大排序输出。
单词仅包括字母,但可能大小写并存(大写不一定只出现在首字母)。
相似单词说明:
给定一个单词X,如果通过任意交换单词中字母的位置得到不同的单词Y,那么定义Y是X的相似单词,如abc、bca即为相似单词(大小写是不同的字母,如a和A算两个不同字母)。
字典序排序: 大写字母<小写字母。同样大小写的字母,遵循26字母顺序大小关系。即A<B<C<…<X<Y<Z<a<b<c<…<x<y<z。
如Bac<aBc<acB<cBa。
二、输入描述
第一行为给定的单词个数N(N为非负整数);
从第二行到第N+1行是具体的单词(每行一个单词);
最后一行是指定的待检测单词(用于检测上面给定的单词中哪些是与该指定单词是相似单词,该单词可以不是上面给定的单词);
三、输出描述
从给定的单词组中,找出指定单词的相似单词,并且按照从小到大字典序排列输出,中间以空格隔开;
如果不存在,则输出null(字符串null)。
四、测试用例
测试用例1
1、输入
4
abc
bca
这篇博客介绍了如何使用Java解决华为OD机试中的一道题目——寻找给定单词字典中与指定单词相似的单词。博客详细阐述了问题描述、输入输出格式,并给出了解题思路和完整的Java算法源码。最后展示了程序运行效果,输出了相似单词并按字典序排序。
订阅专栏 解锁全文
447

被折叠的 条评论
为什么被折叠?



