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。

相关推荐
老鼠只爱大米几秒前
LeetCode算法题详解 42:接雨水
leetcode·动态规划·双指针·单调栈·接雨水·雨水收集
毕设源码-朱学姐7 分钟前
【开题答辩全过程】以 高校图书馆管理系统为例,包含答辩的问题和答案
java
xie_pin_an9 分钟前
C++ 从入门到进阶:核心知识与实战指南
java·c++·算法
Wpa.wk9 分钟前
性能测试-初识性能测试基础(性能测试流程,计划等)
java·运维·经验分享·测试工具·性能测试
小鸡脚来咯15 分钟前
Java 关键字面试解释指南
java
AlenTech24 分钟前
739. 每日温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
毕设源码-郭学长39 分钟前
【开题答辩全过程】以 高校图书推荐系统的设计与实现为例,包含答辩的问题和答案
java
主公不搬砖39 分钟前
Nacos 2.5.2 国产信创 kingbase适配
java·docker·nacos·信创·kingbase·国产适配
谷隐凡二1 小时前
Kubernetes Route控制器简单介绍
java·容器·kubernetes
老鼠只爱大米1 小时前
LeetCode算法题详解 11:盛最多水的容器
leetcode·面试题·双指针·盛最多水的容器·面积最大化