• 去除字符串中重复字符


    题目

    设计算法并写出代码移除字符串中重复的字符,不能使用额外的缓存空间。注意: 可以使用额外的一个或两个变量,但不允许额外再开一个数组拷贝。

    进一步地,

    为你的程序写测试用例。

    解答

    这道题目其实是要你就地(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]='';
    }
    
    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] = '';    
    }
  • 相关阅读:
    Button 的CommandName 用法
    如何循序渐进向DotNet架构师发展
    用sqlserver进行分布式查询(链接服务器)(转)
    关于.resx
    OO设计原则总结
    为ASP.NET 2.0网站生成唯一程序集
    依赖倒置、控制反转和依赖注入辨析(转)
    通过http地址获取页面内容
    Sql同表去除重复
    动态启动WCF服务
  • 原文地址:https://www.cnblogs.com/wuchanming/p/4447792.html
Copyright © 2020-2023  润新知