noaman_wgs

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  233 随笔 :: 0 文章 :: 5 评论 :: 10万 阅读
< 2025年1月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8

 【题目】 

请实现一个算法,确定一个字符串的所有字符是否全都不同。这里我们要求不允许使用额外的存储结构。
给定一个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;
    }
}
复制代码

 

posted on   noaman_wgs  阅读(253)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
阅读排行:
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· https证书一键自动续期,帮你解放90天限制
· 在线客服系统 QPS 突破 240/秒,连接数突破 4000,日请求数接近1000万次,.NET 多
· 推荐几个不错的 Linux 服务器管理工具
· C# 开发工具Visual Studio 介绍
点击右上角即可分享
微信分享提示