面试题10:去除字符串中的重复字符
2016-03-22 21:33 Keiven_LY 阅读(20779) 评论(0) 编辑 收藏 举报题目描述:
设计算法并写出代码移除字符串中重复的字符,不能使用额外的缓存空间。注意:可以使用额外的一个或两个变量,但不允许额外再开一个数组拷贝。进一步地,为你的程序写测试用例。
解题思路:
这道题目其实是要你就地(in place)将字符串中重复字符移除。你可以向面试官问清楚,不能使用额外的一份数组拷贝是指根本就不允许开一个数组,还是说可以开一个固定大小,与问题规模(即字符串长度)无关的数组。
如果根本就不允许你再开一个数组,只能用额外的一到两个变量。那么,你可以依次访问这个数组的每个元素,每访问一个,就将该元素到字符串结尾的元素中相同的元素去掉( 比如置为’’),时间复杂度为O(n2 )。
string removeDuplicate2(string s) { int len = s.length(); if(len < 2) return s; string str = ""; for(int i=0; i<len; ++i) { if(s[i] != ' ') { str += s[i]; for(int j=i+1; j<len; ++j) { if(s[j]==s[i]) { s[j] = ' '; } } } } return str; }
测试用例:
- 不包含重复字符的字符串,比如:abcd
- 字符串全是重复字符,比如:aaaa
- 空字符串
- 重复字符连续出现,比如:aaabbb
- 重复字符不连续出现,比如:abababa
int main() { string s1 = "abcde"; string s2 = "aaabbb"; string s3 = ""; string s4 = "abababc"; string s5 = "ccccc"; cout<<removeDuplicate2(s1)<<endl; cout<<removeDuplicate2(s2)<<endl; cout<<removeDuplicate2(s3)<<endl; cout<<removeDuplicate2(s4)<<endl; cout<<removeDuplicate2(s5)<<endl; return 0; }
测试结果:
abcde
ab
abc