finding anagrams(颠倒字母而成的字) of a given word; 编程珠玑之如何找出一个单词的换位词; 如何找出字典中的兄弟单词
来源:互联网 发布:java 获取项目路径 编辑:程序博客网 时间:2024/06/05 08:59
这篇文章主要是描述一个单词的变体或者变换。
问题的描述:
在编程珠玑里面是这样的:
据说是百度的一个面试题,是这样描述的:
其实总结下问题描述其实是差不多的:给定一个字典(即单词序列),用户输入一个单词,求出字典中单词的变换?
一:
看到这个题目后,直觉是可能是这样的:求出输入单词的全部变换(假如单词的长度是n,则其全部变换有n!个。如果有相同的字母就不是n!了吧?),求出单词的变换后,判断每个变换是否在字典中。
例如对于输入abc,则其变换有3!=6种:abc、acb、bca、bac、cab、cba。然后在依次判断这6个单词(当然这里不是单词了,而是字符串)是否在字典中,如果在字典中则记录下来。
很明显这种思想的复杂度是比较高的,因为对于n稍微大点的话,n!是一个很可怕的递增过程,因此这个方法是不太可取的。
二:
考虑使用hash的方法。构造一个hash函数,该函数使得单词的变换具有相同的hash值。
可以构造这样的函数,给定一个字符串,其hash值是字符串中字母的有序排列。例如字符串cda对应的hash值是acd;zhang的hash值是aghnz,即是字母从小到大的排列。这样对于一个单词的变换其hash值是相同的。
有上面的介绍后可以根据下面的步骤来进行了:
1、根据输入单词求出其hash值,即将单词按字母从小到大进行排列。
2、遍历给定的字典,对于字典里的每个单词,求出其hash值,然后和上一步中求出的hash值进行比较,如果相等,那么这个单词就是输入单词的一个变换,否则不是。
当然上面的方法是可行的。不过时间复杂度是比较高的:
word_hash = hash(word); //如果使用快排,复杂度是nlgn
for(i=0; i<n; i++)//n
{
temp = hash(dic[i]); //nlgn
if(strcmp(temp, word_hash) == 0)
{
output dic[i];
}
}
总的时间复杂度是n*nlgn(不知道算的正确不),当然,如果hash的时间复杂度降低的话还是很不错的。
通过上面可以知道其实可以提前求出字典中单词的hash值,然后再进行匹配的。这样可以有一个变化的方法:
利用c++中的mutilmap或者其他容器,将hash值和字典中的单词昨为一个pair保存在mutilmap中。pair的情况是:<hash(word), word>,其中hash(word)作为map的key,word作为value。
这样就可以遍历map进行判断了。当然也可以先对map进行排序,这样会更快点。
这大概就是这个题目的思路。
编程珠玑上有一些简单的介绍和一个程序实现;这本 STL.Tutorial.and.Reference.Guide 的第12~15章节都是分析了这个问题,不断的改进,是一个很详细的介绍,值得学习。
- finding anagrams(颠倒字母而成的字) of a given word; 编程珠玑之如何找出一个单词的换位词; 如何找出字典中的兄弟单词
- finding anagrams(颠倒字母而成的字) of a given word; 编程珠玑之如何找出一个单词的换位词; 如何找出字典中的兄弟单词
- 如何找出字典中的兄弟单词...
- 如何找出字典中的兄弟单词
- 如何找出字典中的兄弟单词
- 如何找出字典中的兄弟单词
- 如何找出字典中的兄弟单词
- 如何找出字典中的兄弟单词
- 如何找出字典中的兄弟单词
- 找出字典中的兄弟单词
- 找出字典中的兄弟单词
- 给你一个单词a,如果通过交换单词中字母的顺序可以得到另外的单词b,那么定义b是a的兄弟单词。现在给你一个字典,用户输入一个单词,让你根据字典找出这个单词有多少个兄弟单词。
- 用户输入一个单词,要求在一个字典中找出该单词的所有兄弟单词,并输出
- 用户输入一个单词,要求在一个字典中找出该单词的所有兄弟单词,并输出
- 如何快速找出单词的变位词
- 找出最长的一个单词
- Anagrams问题(颠倒字母形成的新单词)
- 给定一个字符串列表,找出单词中最长单词,可以用l列表中的其他单词一次构建一个字符。返回具有最小字典顺序的最长单词。
- tomcat如何将根目录设为web工程目录
- 轉換
- driver_object结构几个域的说明
- Writestring无法写入数据(中文文本)
- 李实名的现代生活之 备忘录模式
- finding anagrams(颠倒字母而成的字) of a given word; 编程珠玑之如何找出一个单词的换位词; 如何找出字典中的兄弟单词
- ArcGIS10.0操作之9——如何建立文字注记和距离注记
- C#完成串口编程的实现
- 我的visual 2008 90天试用版过期了怎么办
- [转帖]如何给Xen Server装上GCC
- 如何分析和研究Log文件(转)
- asp.net UpdatePanel的简单用法
- http://del.cnblogs.com/ 万一的博客
- delphi copyrect实现的几个图片的转换效果