4道题目
242.有效的字母异位词
349. 两个数组的交集
202. 快乐数
1. 两数之和
解题理解
242
异位词的第一个特征就是两者长度一致,长度不一致也就没必要去比较了。其次是两者的每种元素个数一致。遇到这种长度已知,种类数量已知的情况,可以用数组提高很多效率。这题就可以用一个26长度的数组存储string1的种类个数(因为题目要求字符串内只有小写字母,所以最多26种),数组索引表示字母表中第index个,数组内容表示第index个字母有n个。最后遍历string2,string2中的元素每出现一次,都要在数组对应位置-1,这样只要出现一个小于0的字母,就可以判断出两者不是异位词。
class Solution {
public:
bool isAnagram(string s, string t) {
if(s.size() != t.size()) return false;
int set[26] = {0};
for(int i = 0; i < s.size(); i ++){
set[s[i] - 'a'] ++;
}
for(int i = 0; i < t.size(); i ++){
if(--set[t[i] - 'a'] < 0) return false;
}
return true;
}
};
349
这题也可以用数组做,不过C++的容器有些不熟练,看了题解用了unordered_set,该容器自带去重功能,正好符合题干中nums1,nums2有可能有重复元素,但结果不能有重复元素。
思路也比较简单,将nums1放入去重的unordered_set,遍历nums2去unordered_set里找nums2的元素,找到就存入另一个unordered_set,最后以要求的格式返回。
同样的容器思路也可以用在python,python里的set可以对list无序去重,同时python还支持求交集功能,这样仅需一行代码就可以求出。
202
求快乐数的出口在于求到1,出不来是因为无限循环,无限循环是因为求快乐数的过程中出现了一个之前求过的数,因此也是一道去重性质的题,还可以继续用unordered_set,具体思路也比较简单,每个数都求一次快乐数存进unordered_set里,并且查询一次。
就是在求不确定位数快乐数时卡了半天,还写错了。。。
1
一开始想的还是用unordered_set,后来又仔细读题后发现,题目要求的是下标,而不是具体的值,看了题解后学习了一下unordered_map的用法。
map的存储格式为{value,index},遍历nums的过程中不断确认target-nums[i]有没有出现在map里,没有就将nums[i]和i存入map,如果出现就return。
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
unordered_map<int, int> map;
for(int i = 0; i < nums.size(); i ++){
auto iter = map.find(target - nums[i]);
if(iter != map.end()){
return {iter->second, i};
}else{
map.insert(pair<int, int>(nums[i], i));
}
}
return {};
}
};
值得注意的是,这里的second指的是map中index位,题目并不需要求出value。