当前位置: 首页 > news >正文

vs做网站创建项目时选哪个下载公众号

vs做网站创建项目时选哪个,下载公众号,手机制作公章的软件,wordpress root权限❓205. 同构字符串 难度:简单 给定两个字符串 s 和 t ,判断它们是否是同构的。 如果 s 中的字符可以按某种映射关系替换得到 t ,那么这两个字符串是同构的。 每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同…

❓205. 同构字符串

难度:简单

给定两个字符串 st ,判断它们是否是同构的。

如果 s 中的字符可以按某种映射关系替换得到 t ,那么这两个字符串是同构的。

每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同字符不能映射到同一个字符上,相同字符只能映射到同一个字符上,字符可以映射到自己本身。

示例 1:

输入:s = “egg”, t = “add”
输出:true

示例 2:

输入:s = “foo”, t = “bar”
输出:false

示例 3:

输入:s = “paper”, t = “title”
输出:true

提示:

  • 1 < = s . l e n g t h < = 5 ∗ 1 0 4 1 <= s.length <= 5 * 10^4 1<=s.length<=5104
  • t.length == s.length
  • st 由任意有效的 ASCII 字符组成

💡思路:

法一:定长数组

由于 st 由任意有效的 ASCII 字符组成,ASCII 对应的十进制为 0 ~ 255,所以可以定义两个长度为256的数组,就能包括所有字符:

  • 数组中记录一个字符上一次出现在字符串中的位置;
  • 如果两个字符串中的字符上一次出现的位置一样,那么就属于同构。

法二:哈希表

由于不同字符不能映射到同一个字符上,所以两个字符串的映射关系都必须一一对应,不能出现一对多的情况,这里设置两个哈希表,分别存储两个字符串中已建立映射关系的字符:

  • 同时遍历字符串 s 和字符串 t 的相同位置,建立映射关系;
  • 如果s 的字符已经在哈希表中,则判断t对应位置的字符是否等于哈希表中的映射,如果不等,则返回false,相等则继续遍历。
  • 如果字符串 st 的字符都不在哈希表中,则将st对应位置的映射关系存储到哈希表中;
  • 否则不是同构字符串,返回false
  • 最后返回true

🍁代码:(Java、C++)

法一:定长数组
Java

class Solution {public boolean isIsomorphic(String s, String t) {int[] preIndexOfS = new int[256];int[] preIndexOfT = new int[256];for(int i = 0; i < s.length(); i++){char sc = s.charAt(i), tc = t.charAt(i);if(preIndexOfS[sc] != preIndexOfT[tc]){return false;} preIndexOfS[sc] = i + 1;preIndexOfT[tc] = i + 1;}return true;}
}

C++

class Solution {
public:bool isIsomorphic(string s, string t) {vector<int> preIndexOfS(256);vector<int> preIndexOfT(256);for (int i = 0; i < s.size(); i++) {if (preIndexOfS[s[i]] != preIndexOfT[t[i]]) {return false;}preIndexOfS[s[i]] = i + 1;preIndexOfT[t[i]] = i + 1;}return true;}
};

法二:哈希表
Java

class Solution {public boolean isIsomorphic(String s, String t) {Map<Character, Character> mapping = new HashMap<>();Set<Character> setting = new HashSet<>();for(int i = 0; i < s.length(); i++){char sc = s.charAt(i), tc = t.charAt(i);if(mapping.containsKey(sc)){if(mapping.get(sc) != tc) return false;}else if(!setting.contains(tc)){mapping.put(sc, tc);setting.add(tc);}else{return false;}}return true;}
}

C++

class Solution {
public:bool isIsomorphic(string s, string t) {unordered_map<char, char> mapping;unordered_set<char> setting;for(size_t i = 0; i < s.size(); i++){if(mapping.find(s[i]) != mapping.end()){if(mapping[s[i]] != t[i]) return false;}else if(setting.find(t[i]) == setting.end()){mapping.insert({s[i], t[i]});setting.insert(t[i]);}else{return false;}}return true;}
};

🚀 运行结果:

在这里插入图片描述

🕔 复杂度分析:

  • 时间复杂度 O ( n ) O(n) O(n),其中 n 为字符串s的长度。
  • 空间复杂度 O ( S ) O(S) O(S),其中 S 为字符集大小。法一:我们使用了一个长度为 256 的数组,存储每个字符出现的次数。法二:哈希表存储字符的空间取决于字符串的字符集大小,最坏情况下每个字符均不相同。

题目来源:力扣。

放弃一件事很容易,每天能坚持一件事一定很酷,一起每日一题吧!
关注我 leetCode专栏,每日更新!

注: 如有不足,欢迎指正!

http://www.yayakq.cn/news/131677/

相关文章:

  • 千秋网络是家西安做网站的公司简述网站推广的方式
  • 做汽车导航仪在什么网站找客户中文去掉wordpress
  • wordpress出站链接软件平台下载
  • 营销型网站策划 建设的考试题wordpress视频上传太小
  • 天津免费做网站成品网站货源1277
  • 网站建设的一般过程包括哪些内容谷歌做公司网站需要多少钱
  • 在线教育网站策划方案工商天眼查官网
  • 南岸网站关键词优化社保网站做员工用工备案
  • 做搜狗手机网站优化wordpress自动标签添加内链插件
  • wordpress动态添加字段优化深圳seo
  • 产品营销类网站南京网站建
  • 网站备案地区名河源市地震
  • 网站建设鼎网络wordpress响应式模版
  • 微餐饮网站建设用途丰台区的建设网站
  • 聊城做手机网站建设网站空间被挂马
  • 网站开发项目管理网店运营推广方案
  • 团购网站建设流程平台期是什么意思
  • 做维修家具广告在哪个网站好新人做外贸哪个平台好做
  • 重庆塔吊证查询网站网站程序上传教程
  • 网站维护要求苏州企业管理咨询服务
  • 网上接网站开发类订单的平台云服务器和网站空间
  • 中国建设银行网上银行网站济南莱芜最新消息
  • 企业网站如何建设报告黄山网络推广哪家好
  • 做网站好的百度网站地图生成器
  • 廊坊seo整站优化软件如何做网站产品经理
  • 商城网站建设行业现状wordpress导航
  • 电子商务的建站流程极简风格网站介绍
  • 微信h5免费制作网站理财公司网站模板下载
  • 网站怎么推广效果好世界500强企业排行榜中国企业
  • 企业网站为什么都选千博企业网站wordpress 插件 缓存