LeetCode:3083. 字符串及其反转中是否存在同一子字符串(哈希 Java)

目录

[3083. 字符串及其反转中是否存在同一子字符串](#3083. 字符串及其反转中是否存在同一子字符串)

题目描述:

实现代码与解析:

二进制哈希

原理思路:


3083. 字符串及其反转中是否存在同一子字符串

题目描述:

给你一个字符串 s ,请你判断字符串 s 是否存在一个长度为 2 的子字符串,在其反转后的字符串中也出现。

如果存在这样的子字符串,返回 true;如果不存在,返回 false

示例 1:

**输入:**s = "leetcode"

**输出:**true

解释: 子字符串 "ee" 的长度为 2,它也出现在 reverse(s) == "edocteel" 中。

示例 2:

**输入:**s = "abcba"

**输出:**true

解释: 所有长度为 2 的子字符串 "ab""bc""cb""ba" 也都出现在 reverse(s) == "abcba" 中。

示例 3:

**输入:**s = "abcd"

**输出:**false

解释: 字符串 s 中不存在满足「在其反转后的字符串中也出现」且长度为 2 的子字符串。

提示:

  • 1 <= s.length <= 100
  • 字符串 s 仅由小写英文字母组成。

实现代码与解析:

二进制哈希

java 复制代码
class Solution {
    public boolean isSubstringPresent(String s) {
        char[] cs = s.toCharArray();

        int[] hash = new int[26];

        for (int i = 1; i < cs.length; i++) {
            int x = cs[i - 1] - 'a';
            int y = cs[i] - 'a';
            hash[x] |= 1 << y;
            if ((hash[y] >> x & 1) > 0) {
                return true;
            }
        }
        return false;
    }
}

原理思路:

hash判断一下长度为2的子串是否已经被遍历过即可。因为字母有限,可以直接用二进制来代表一个纬度的hash。

相关推荐
seabirdssss4 分钟前
使用Spring Boot DevTools快速重启功能
java·spring boot·后端
喂完待续12 分钟前
【序列晋升】29 Spring Cloud Task 微服务架构下的轻量级任务调度框架
java·spring·spring cloud·云原生·架构·big data·序列晋升
benben04415 分钟前
ReAct模式解读
java·ai
金古圣人34 分钟前
hot100 滑动窗口
数据结构·c++·算法·leetcode·哈希算法
轮到我狗叫了1 小时前
牛客.小红的子串牛客.kotori和抽卡牛客.循环汉诺塔牛客.ruby和薯条
java·开发语言·算法
YuTaoShao2 小时前
【LeetCode 热题 100】49. 字母异位词分组
算法·leetcode·哈希算法
Volunteer Technology2 小时前
三高项目-缓存设计
java·spring·缓存·高并发·高可用·高数据量
栗子~~2 小时前
bat脚本- 将jar 包批量安装到 Maven 本地仓库
java·maven·jar
Mr.Entropy3 小时前
ecplise配置maven插件
java·maven
叙白冲冲3 小时前
tomcat 为啥能一直运行?不像方法那样结束?
java·tomcat