确定字符互异

Posted noaman_wgs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了确定字符互异相关的知识,希望对你有一定的参考价值。

 【题目】 

请实现一个算法,确定一个字符串的所有字符是否全都不同。这里我们要求不允许使用额外的存储结构。
给定一个string iniString,请返回一个bool值,True代表所有字符全都不同,False代表存在相同的字符。保证字符串中的字符为ASCII字符。字符串的长度小于等于3000。

测试样例:
"aeiou"
返回:True
"BarackObama"
返回:False

解法:

1  不使用额外存储结构:

import java.util.*;

public class Different {
    public boolean checkDifferent(String initString) {
        
        //超出256个字符肯定会有重复
        if (initString == null || initString.length() <= 0 || initString.length() > 256){
            return false;
        }
        
        int len = initString.length();
        for(int i = 0;i < len;i++){
            //获取ASCII码
            char c = initString.charAt(i);
            int cNum = Integer.valueOf(c);
            for (int j = i + 1;j < len;j++){
                char tempC = initString.charAt(j);
                int tempCNum = Integer.valueOf(tempC);
                if((cNum - tempCNum) == 0){
                    return false;
                }
            }
           
        }
        
        return true;
    }
}

 

2  使用额外存储结构:

import java.util.*;

public class Different {
    public boolean checkDifferent(String iniString) {
        if(iniString == null || iniString.length() <= 0)
            return false;
        Set set = new HashSet();
        for(int i=0; i < iniString.length(); i++){
            if(!set.add(iniString.charAt(i))){
                return false;
            }
            set.add(iniString.charAt(i));
        }
        return true;
    }
}

 

以上是关于确定字符互异的主要内容,如果未能解决你的问题,请参考以下文章

第二章 集合 字符编码

CC150

Android:通过片段进行相机预览。从活动中确定

JAVA核心技术I---JAVA基础知识(集合set)

第二问不能用数学归纳法

片段中的getView()导致抛出异常,不确定原因