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。

相关推荐
No0d1es12 分钟前
电子学会青少年软件编程(C/C++)1级等级考试真题试卷(2025年9月)
java·c语言·c++·青少年编程·电子学会·真题·一级
9号达人34 分钟前
普通公司对账系统的现实困境与解决方案
java·后端·面试
超级苦力怕36 分钟前
Java 为何 long a = 999999999 能过;long a = 9999999999 报错?一文讲透“宽化转换”
java
佐杰41 分钟前
Jenkins使用指南1
java·运维·jenkins
dllxhcjla1 小时前
三大特性+盒子模型
java·前端·css
小白程序员成长日记1 小时前
2025.11.06 力扣每日一题
算法·leetcode
Acrelhuang1 小时前
筑牢用电防线:Acrel-1000 自动化系统赋能 35kV 园区高效供电-安科瑞黄安南
java·大数据·开发语言·人工智能·物联网
脸大是真的好~1 小时前
黑马JAVAWeb-10 文件上传-文件存储到服务器本地磁盘-文件存储在阿里云OSS-@Value属性注入
java
大G的笔记本1 小时前
算法篇常见面试题清单
java·算法·排序算法
亚林瓜子1 小时前
Spring中的异步任务(CompletableFuture版)
java·spring boot·spring·async·future·异步