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。

相关推荐
暴力袋鼠哥1 分钟前
基于springboot与vue的ai多模态数据展示看板
java·spring boot
wfbcg5 分钟前
每日算法练习:LeetCode 76. 最小覆盖子串 ✅
算法·leetcode·职场和发展
用户83071968408211 分钟前
VS Code Java开发配置与使用经验分享
java·visual studio code
立莹Sir14 分钟前
云原生全解析:从概念到实践,Java技术栈如何拥抱云原生时代
java·开发语言·云原生
程序员老邢25 分钟前
【技术底稿 12】内网统一日志系统 Loki + Promtail 全流程部署(对接 Grafana,监控日志一体化)
java·运维·程序人生·grafana·devops
银河系的一束光29 分钟前
使用 IntelliJ IDEA 开发 Java 程序时 , 会遇到以下中文乱码问题 :
java·ide·intellij-idea
Via_Neo36 分钟前
判断字符串前缀(26年蓝桥杯JAVA B组)
java·职场和发展·蓝桥杯
XiYang-DING43 分钟前
【Java】从源码深入理解HashMap和TreeMap
java·开发语言
wangwangmoon_light1 小时前
1.23 LeetCode总结(树)_一般树
算法·leetcode·职场和发展