Day 6 第三章 哈希表part01

Day 6 第三章 哈希表part01

  • 解题理解
    • 242
    • 349
    • 202
    • 1

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。

你可能感兴趣的:(散列表,数据结构)