确定字符互异

题目描述

请实现一个算法,确定一个字符串的所有字符是否全都不同。这里我们要求不允许使用额外的存储结构。

给定一个string iniString,请返回一个bool值,True代表所有字符全都不同,False代表存在相同的字符。保证字符串中的字符为ASCII字符。字符串的长度小于等于3000。

class Different {
public:
    bool checkDifferent(string iniString) {
        if(iniString.length() > 256)
            return false;
        
        bool char_set[256] = {0};
        for(int i = 0;i < iniString.length();i++){
            int val = iniString[i];
            if(char_set[val]){
                return false;
            }
            char_set[val] = true;
        }
        return true;
    }
};

 

posted on 2017-04-01 16:35  123_123  阅读(84)  评论(0编辑  收藏  举报