我是陈皮,一个在互联网 Coding 的 ITer,微信搜索「陈皮的JavaLib」第一时间阅读最新文章,回复【资料】,即可获得我精心整理的技术资料,电子书籍,一线大厂面试资料和优秀简历模板。

题目

实现一个算法,确定一个字符串 s 的所有字符是否全都不同。

示例1:

  • 输入: s = "leetcode"
  • 输出:false

示例2:

  • 输入:s = "abc"
  • 输出:true

限制

  • 0 <= len(s) <= 100
  • 如果你不使用额外的数据结构,会很加分。

题目来源:LeetCode

解法一

判断一个字符串中所有字符是否唯一,最简单的暴力求解就是两两对比是否相同,即双重循环,但是算法复杂度为 O(n^2),性能也是最低的。如果字符串的长度是比较小的话,此算法也是勉强可以使用的。

package com.chenpi;

/**
* @Description 实现一个算法,确定一个字符串 s 的所有字符是否全都不同。
* @Author Mr.nobody
* @Date 2021/4/18
* @Version 1.0
*/
public class StrIsUnique { public boolean isUnique(String astr) {
// 字符串为null或者为空,自然没有字符重复,即唯一
if (null == astr || 0 == astr.length()) {
return true;
}
// 双重循环,两两对比
for (int i = 0; i < astr.length() - 1; i++) {
for (int j = i + 1; j < astr.length(); j++) {
if (astr.charAt(i) == astr.charAt(j)) {
return false;
}
}
}
return true;
} public static void main(String[] args) {
String astr = "leetcode";
StrIsUnique strIsUnique = new StrIsUnique();
System.out.println(strIsUnique.isUnique(astr));
}
}

解法二

既然是判断唯一性,那我们可以遍历每一个字符,然后通过某种规则将它们放入指定位置,因为相同字符肯定会被放到相同的位置,我们只需要判断放入此位置之前是否有字符放入过,如果有,就代表有重复的字符。借助散列表这种数据结构就能达到这种效果。

package com.chenpi;

import java.util.HashMap;
import java.util.Map; /**
* @Description 实现一个算法,确定一个字符串 s 的所有字符是否全都不同。
* @Author Mr.nobody
* @Date 2021/4/18
* @Version 1.0
*/
public class StrIsUnique { public boolean isUnique(String astr) {
// 字符串为null或者为空,自然没有字符重复,即唯一
if (null == astr || 0 == astr.length()) {
return true;
}
Map<Character, Integer> map = new HashMap<>(astr.length() + 1);
// 遍历每一个字符,从map中判断是否存在相同的字符
for (int i = 0; i < astr.length(); i++) {
// 存在相同的字符
if (null != map.get(astr.charAt(i)) && map.get(astr.charAt(i)) == 1) {
return false;
}
// 在map中不存在此字符,放入map中
map.put(astr.charAt(i), 1);
}
return true;
} public static void main(String[] args) {
String astr = "陈皮的JavaLib";
StrIsUnique strIsUnique = new StrIsUnique();
System.out.println(strIsUnique.isUnique01(astr));
}
}

解法三

如果我们不再借助其他数据结构,如何解法呢?因为要求唯一性,肯定要有字符比较的。解法二我们借助了散列表这种数据结构,结果内存消耗方面只击败了27.28%的用户。

假设字符串中的字符是26个小写字母,解法二是将每一个字符放入散列表中,如果散列表中每一个位置都没有重复的字符,则唯一性。那我们可以将每一个字符映射到一个二进制数组中,通过与运算,如果相同位置都为1,则结果为1,则代表有重复字符。

借助一个初始值为0的int变量mark,二进制形式为0000...0000,遍历每一个字符,计算字符与a字符的距离move_bit,然后使用左移运算符1 << move_bit创建对应下标为1,其余下标为0的数num。将num与mark做与运算,如果结果不为0,则代表有重复字符。如果结果为0,则代表这个字符之前没出现过,将num和mark通过或运算的结果赋值给mark,即在mark中将此字符的对应下标的值设为1。

package com.chenpi;

import java.util.HashMap;
import java.util.Map;
import java.util.function.BinaryOperator; /**
* @Description 实现一个算法,确定一个字符串 s 的所有字符是否全都不同。
* @Author Mr.nobody
* @Date 2021/4/18
* @Version 1.0
*/
public class StrIsUnique { public boolean isUnique02(String astr) {
// 字符串为null或者为空,自然没有字符重复,即唯一
if (null == astr || 0 == astr.length()) {
return true;
}
int mark = 0;
int num = 0;
// 遍历每一个字符
for (int i = 0; i < astr.length(); i++) {
num = 1 << (astr.charAt(i) - 'a');
// 通过与运算判断对应下标是否都为1,即是否有相同字符
if ((mark & num) != 0) {
return false;
}
// 在map中将对应下标置为1
mark |= num;
}
return true;
} public static void main(String[] args) {
String astr = "javalib";
StrIsUnique strIsUnique = new StrIsUnique();
System.out.println(strIsUnique.isUnique02(astr));
}
}

上一题与下一题

上一题LeetCode 每日一题「实现 strStr()」

下一题LeetCode 每日一题「判定是否互为字符重排」

LeetCode 每日一题「判定字符是否唯一」的更多相关文章

  1. Leetcode 面试题 01.01. 判定字符是否唯一

    实现一个算法,确定一个字符串 s 的所有字符是否全都不同. 示例 1: 输入: s = "leetcode"输出: false 示例 2: 输入: s = "abc&qu ...

  2. 【JavaScript】Leetcode每日一题-青蛙过河

    [JavaScript]Leetcode每日一题-青蛙过河 [题目描述] 一只青蛙想要过河. 假定河流被等分为若干个单元格,并且在每一个单元格内都有可能放有一块石子(也有可能没有). 青蛙可以跳上石子 ...

  3. 【python】Leetcode每日一题-扰乱字符串

    [python]Leetcode每日一题-扰乱字符串 [题目描述] 使用下面描述的算法可以扰乱字符串 s 得到字符串 t : 如果字符串的长度为 1 ,算法停止 如果字符串的长度 > 1 ,执行 ...

  4. 【JavaScript】Leetcode每日一题-在D天内送包裹的能力

    [JavaScript]Leetcode每日一题-在D天内送包裹的能力 [题目描述] 传送带上的包裹必须在 D 天内从一个港口运送到另一个港口. 传送带上的第 i 个包裹的重量为 weights[i] ...

  5. 【JavaScript】【dp】Leetcode每日一题-解码方法

    [JavaScript]Leetcode每日一题-解码方法 [题目描述] 一条包含字母 A-Z 的消息通过以下映射进行了 编码 : 'A' -> 1 'B' -> 2 ... 'Z' -& ...

  6. 【JavaScript】【KMP】Leetcode每日一题-实现strStr()

    [JavaScript]Leetcode每日一题-实现strStr() [题目描述] 实现 strStr() 函数. 给你两个字符串 haystack 和 needle ,请你在 haystack 字 ...

  7. 【JavaScript】Leetcode每日一题-移除元素

    [JavaScript]Leetcode每日一题-移除元素 [题目描述] 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度. 不要使用 ...

  8. 【python】Leetcode每日一题-删除有序数组中的重复项

    [python]Leetcode每日一题-删除有序数组中的重复项 [题目描述] 给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 最多出现一次 ,返回删除后数组的新长度. 不要 ...

  9. [LeetCode每日一题]153.寻找旋转排序数组中的最小值

    [LeetCode每日一题]153.寻找旋转排序数组中的最小值 问题 已知一个长度为 n 的数组,预先按照升序排列,经由 1 到 n 次 旋转 后,得到输入数组.例如,原数组 nums = [0,1, ...

随机推荐

  1. 记一次CTF的签到题

    开篇 打开题目网站 首先看到的是一个人博客,功能点非常少,功能较多的页面就是留言板了 一开始没啥思路,就想着抓包能不能找到SQL注入无果,在这个地方卡了很久 柳暗花明 在乱点的时候,无意中发现题目中的 ...

  2. Asp.NetCore Web应用程序中的请求管道和中间件

    你是否会迷惑当我们请求一个ASP.NetWeb应用程序以后,它是怎么处理这些请求的,后台是怎么工作的,今天就讲一下Asp.NetCore Web应用程序中的请求处理过程. 上一节,我们讲到,Start ...

  3. 集成Spring Data JPA

    1.Spring Data JPA简介 Spring Data是一个用于简化数据访问,并支持云服务的开源框 使用完成Spring Data JPA对user表的CRUD操作. 2.步骤 1.创建工程勾 ...

  4. 安装过程中出现一个错误: No such plugin: cloudbees-folder

    上面的错误显示是,安装插件cloudbees-folder失败,是因为下载的Jenkins.war里没有cloudbees-folder插件 需要去 https://updates.jenkins-c ...

  5. linux如何patch打补丁

    1. 创建2个文件 1.txt 和 2.txt 并在1.txt基础上修改成为2.txt book@100ask:~/patch$ ls 1.txt 2.txt book@100ask:~/patch$ ...

  6. 在Visual Studio 中使用git——浏览版本库(七)

    在Visual Studio 中使用git--什么是Git(一) 在Visual Studio 中使用git--给Visual Studio安装 git插件(二) 在Visual Studio 中使用 ...

  7. Canal和Otter介绍和使用

    Canal Canal原理 原理相对比较简单: canal模拟mysql slave的交互协议,伪装自己为mysql slave,向mysql master发送dump协议 mysql master收 ...

  8. k8s总结复习

    一.k8s介绍 Kubernetes(k8s)是Google开源的容器集群管理系统.在Docker技术的基础上,为容器化的应用提供部署运行.资源调度.服务发现和动态伸缩等一系列完整功能,提高了大规模 ...

  9. ubuntu中安装visual studio code-(转载)

    在Ubuntu中安装Visual Studio Code 编译自:http://itsfoss.com/install-visual-studio-code-ubuntu/ 作者: Abhishek ...

  10. Linux(CentOS 7) 安全加固之非业务端口服务关闭 postfix port 25

    目录 关闭TCP 25 端口对应的服务 1. 确认对应端口的进程 2. 查找与关闭对应服务 3. 确认结果,端口已关闭 关闭TCP 25 端口对应的服务 [0 root@Qvps /root] #ca ...