题目
设计算法并写出代码移除字符串中重复的字符,不能使用额外的缓存空间。注意: 可以使用额外的一个或两个变量,但不允许额外再开一个数组拷贝。
进一步地,
为你的程序写测试用例。
解答
这道题目其实是要你就地(in place)将字符串中重复字符移除。你可以向面试官问清楚, 不能使用额外的一份数组拷贝是指根本就不允许开一个数组,还是说可以开一个固定大小, 与问题规模(即字符串长度)无关的数组。
如果根本就不允许你再开一个数组,只能用额外的一到两个变量。那么,你可以依次访问 这个数组的每个元素时间复杂度为O(n2 ),代码如下:
#include<iostream> #include<cstring> using namespace std;void removeDuplicate(char *str) {if(str==NULL)return;int count=0;int n=strlen(str);for(int i=1;i<n;++i){int j=i-1;while(j>=0){if(str[i]==str[j]){++count;break;}else--j;}if(j<0)str[i-count]=str[i];}str[n-count]='\0'; }int main() {char str[]="";removeDuplicate(str);cout<<str<<endl; }
如果可以开一个固定大小,与问题规模(即字符串长度)无关的数组,那么可以用一个数组来 表征每个字符的出现(假设是ASCII字符,则数组大小为256),这样的话只需要遍历一遍字符 串即可,时间复杂度O(n)。代码如下:
void removeDuplicate(char s[]) {int len = strlen(s);if(len < 2) return;bool c[256];memset(c, 0, sizeof(c));int p = 0;for(int i=0; i < len; ++i){if(!c[s[i]]){s[p++] = s[i];c[s[i]] = true;}}s[p] = ''; }