墙绘网站建设,8种常用的网络营销推广方法,帮别人做ppt挣钱的网站,广州营销型网站建设怎么样242 有效的字母异位词
给定两个字符串 和 #xff0c;编写一个函数来判断 是否是 的字母异位词。stts
注意#xff1a;若 和 中每个字符出现的次数都相同#xff0c;则称 和 互为字母异位词。stst
示例 1:
输入: s “anagram”, t “nagaram” 输出: true 示例 2:
输…242 有效的字母异位词
给定两个字符串 和 编写一个函数来判断 是否是 的字母异位词。stts
注意若 和 中每个字符出现的次数都相同则称 和 互为字母异位词。stst
示例 1:
输入: s “anagram”, t “nagaram” 输出: true 示例 2:
输入: s “rat”, t “car” 输出: false
提示:
1 s.length, t.length 5 * 104 s 和 仅包含小写字母t
解决方案
提供思路
1暴力解法两层for循环同时还要记录字符是否重复出现时间复杂度是 O(n^2)。
2数组其实就是一个简单哈希表而且这道题目中字符串只有小写字符那么就可以定义一个数组来记录字符串s里字符出现的次数。
需要定义一个多大的数组呢定一个数组叫做record大小为26 就可以了初始化为0因为字符a到字符z的ASCII也是26个连续的数值。
定义一个数组叫做record用来上记录字符串s里字符出现的次数。
需要把字符映射到数组也就是哈希表的索引下标上因为字符a到字符z的ASCII是26个连续的数值所以字符a映射为下标0相应的字符z映射为下标25。
再遍历 字符串s的时候只需要将 s[i] - ‘a’ 所在的元素做1 操作即可并不需要记住字符a的ASCII只要求出一个相对数值就可以了。 这样就将字符串s中字符出现的次数统计出来了。
那看一下如何检查字符串t中是否出现了这些字符同样在遍历字符串t的时候对t中出现的字符映射哈希表索引上的数值再做-1的操作。
那么最后检查一下record数组如果有的元素不为零0说明字符串s和t一定是谁多了字符或者谁少了字符return false。
最后如果record数组所有元素都为零0说明字符串s和t是字母异位词return true。
上代码
public class Solution
{public bool IsAnagram(string s, string t){int sl s.Length, tl t.Length;if (sl ! tl) return false;int[] a new int[26];for (int i 0; i sl; i){a[s[i] - a];a[t[i] - a]--;}foreach (int i in a){if (i ! 0)return false;}return true;}
}以上是碰到的第二百四十二题后续持续更新。感觉对你有帮助的小伙伴可以帮忙点个赞噢