当前位置: 首页> 游戏> 手游 > 室内设计网站哪些号_商城型网站建设_seo搜索优化培训_app拉新项目

室内设计网站哪些号_商城型网站建设_seo搜索优化培训_app拉新项目

时间:2025/7/13 18:07:00来源:https://blog.csdn.net/Tisfy/article/details/144746598 浏览次数:0次
室内设计网站哪些号_商城型网站建设_seo搜索优化培训_app拉新项目

【LetMeFly】3083.字符串及其反转中是否存在同一子字符串:哈希表

力扣题目链接:https://leetcode.cn/problems/existence-of-a-substring-in-a-string-and-its-reverse/

给你一个字符串 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 仅由小写英文字母组成。

解题方法:哈希表

开辟一个二维数组visited,其中visited[i][j]表示长度为2的子字符串('a' + i)('a' + j)是否出现过。

遍历字符串,将每个长度为2的子字符串加入哈希表中。若这个子字符串翻转后的字符串在哈希表中出现过,则返回true

最终未返回则返回false

  • 时间复杂度 O ( l e n ( s ) ) O(len(s)) O(len(s))
  • 空间复杂度 O ( C 2 ) O(C^2) O(C2),其中 C = 26 C=26 C=26

AC代码

C++
/** @Author: LetMeFly* @Date: 2024-12-26 15:37:22* @LastEditors: LetMeFly.xyz* @LastEditTime: 2024-12-26 15:39:20*/
class Solution {
public:bool isSubstringPresent(string s) {bool visited[26][26] = {false};for (int i = 1; i < s.size(); i++) {visited[s[i - 1] - 'a'][s[i] - 'a'] = true;if (visited[s[i] - 'a'][s[i - 1] - 'a']) {return true;}}return false;}
};
Python
'''
Author: LetMeFly
Date: 2024-12-26 15:40:00
LastEditors: LetMeFly.xyz
LastEditTime: 2024-12-26 15:41:59
'''
class Solution:def isSubstringPresent(self, s: str) -> bool:visited = [[False] * 26 for _ in range(26)]for i in range(1, len(s)):visited[ord(s[i - 1]) - ord('a')][ord(s[i]) - ord('a')] = Trueif visited[ord(s[i]) - ord('a')][ord(s[i - 1]) - ord('a')]:return Truereturn False
Java
/** @Author: LetMeFly* @Date: 2024-12-26 15:42:36* @LastEditors: LetMeFly.xyz* @LastEditTime: 2024-12-26 15:44:38*/
class Solution {public boolean isSubstringPresent(String s) {boolean[][] visited = new boolean[26][26];for (int i = 1; i < s.length(); i++) {visited[s.charAt(i - 1) - 'a'][s.charAt(i) - 'a'] = true;if (visited[s.charAt(i) - 'a'][s.charAt(i - 1) - 'a']) {return true;}}return false;}
}
Go
/** @Author: LetMeFly* @Date: 2024-12-26 15:45:02* @LastEditors: LetMeFly.xyz* @LastEditTime: 2024-12-26 15:47:44*/
package mainfunc isSubstringPresent(s string) bool {var visited [26][26]boolfor i := 1; i < len(s); i++ {visited[s[i - 1] - 'a'][s[i] - 'a'] = trueif visited[s[i] - 'a'][s[i - 1] - 'a'] {return true}}return false
}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/144746598

关键字:室内设计网站哪些号_商城型网站建设_seo搜索优化培训_app拉新项目

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: