代码改变世界

面试题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;
}

测试用例:

  1. 不包含重复字符的字符串,比如:abcd
  2. 字符串全是重复字符,比如:aaaa
  3. 空字符串
  4. 重复字符连续出现,比如:aaabbb
  5. 重复字符不连续出现,比如: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