字符串常见的问题:
String
charAt(index)
char[]
Map<Character,Integer>
回文,如 abcdcba
分析: 2个指针,一头一尾,逐个比较,都相同就是回文
/*
* eg acdeedca
* @ret 0 success , -1 fail
*/
int is_huiwen(const char *source){
if (source == NULL || source == '\0') return -1;
char *head = source;
char *tail = source;
while(*tail != '\0'){
tail++;
}
tail--;
while(head < tail){
if (*head != *tail){
return -1;
}
head++;
tail--;
}
return 0;
}
设计相应的数据结构和算法,尽量高效的统计一片英文文章(总单词数目)里出现的所有英文单词,按照在文章中首次出现的顺序打印输出该单词和它的出现次数。
void statistics(char *string)
void statistics(FILE *fd)
延伸:
如果是海量数据里面统计top-k次数的单词呢?
也就是实现函数atoi的功能,这道题目考查的就是对各种情况下异常处理。比如:
以213
分析转换成证书的过程。3+1x10+2x100
,思路是:每扫描到一个字符,把 之前得到的数字*10
,再加上当前的数字
- 0开头,"0213"
- 正/负数,"-432" ,"--422","++23"
- 浮点数,"43.2344"
- 非法,"2123des"
- 存在空格," -32"," +432"," 234","23 432","353 "," + 321"
- NULL/空串,这时候返回值0
- 溢出,"32111111112222222222222222222222222222222" , 与
INT_MAX
比较 - 如何区分正常的'0'和异常情况下返回的结果"0"? 可以通过一个全局变量 g_status 来标示,值为 kValid/kInvalid。
int atoi(const char *str){
}
详细过程也可以参考这里
什么是兄弟字符串?
如果两个字符串的字符一样,但是顺序不一样,被认为是兄弟字符串,问如何在迅速匹配兄弟字符串(如,bad和adb就是兄弟字符串)。
思路:判断各自素数乘积是否相等。更多方法请参见:http://blog.csdn.net/v_JULY_v/article/details/6347454。
int isBrother(const char *first,const char *secd)
思路一: 循环匹配 指数级复杂度
思路二: 利用质数,平方和比较,但这样必须是2个串的长度要一样,需要的空间比较大,最多256个字节。
示例代码:
int isBrother(const char *first,const char *secd){
}
题目:输入一个字符串,打印出该字符串中字符的所有排列。例如输入字符串abc,则输出由字符a、b、c所能排列出来的所有字符串abc、acb、bac、bca、cab和cba。输入字符串 abcca,则输出由 a,b,c排列出来的所有字符串,字符出现个数不变
分析:这是一道很好的考查对递归理解的编程题
简单的回溯就可以实现了。当然排列的产生也有很多种算法,去看看组合数学,还有逆序生成排列和一些不需要递归生成排列的方法。
印象中Knuth的第一卷里面深入讲了排列的生成。这些算法的理解需要一定的数学功底,也需要一定的灵感,有兴趣最好看看。
有n个长为m+1的字符串,如果某个字符串的最后m个字符与某个字符串的前m个字符匹配,则两个字符串可以联接,问这n个字符串最多可以连成一个多长的字符串,如果出现循环,则返回错误。
给定一个字符串的集合,格式如:{aaa bbb ccc}, {bbb ddd},{eee fff},{ggg},{ddd hhh}要求将其中交集不为空的集合合并,要求合并完成后的集合之间无交集,例如上例应输出{aaa bbb ccc ddd hhh},{eee fff}, {ggg}。