【算法】代码随想录之哈希表(更新中)

2024-07-21 1575阅读

文章目录

前言

一、有效的字母异位词(LeetCode--242)

二、两个数组的交集(LeetCode--349)

三、两数之和(LeetCode--1)

四、四数相加II(LeetCode--454)

五、三数之和(LeetCode--15)

六、四数之和(LeetCode--18)


前言

跟随代码随想录,学习哈希表相关的算法题目,记录学习过程中的tips。


一、有效的字母异位词(LeetCode--242)

【1】题目描述:

【算法】代码随想录之哈希表(更新中)

【2】解决思想:哈希表中记录每个字母的个数。遍历s字符串,遇到一个字母就使哈希表对应位置+1。遍历t字符串,遇到一个字母就使哈希表对应位置-1。最后,遍历哈希表,若存在不等于0的元素则返回false。

【3】C++代码:

class Solution {
public:
    bool isAnagram(string s, string t) {
        int hash[26] = {0};
        for (int i = 0; i  

【4】时间复杂度:O(N),对于每个字符串只遍历了一次。

【5】空间复杂度:O(N),开辟了额外的哈希表空间。


三、两数之和(LeetCode--1)

【1】题目描述:

【算法】代码随想录之哈希表(更新中)

【2】解决思想:哈希表法。遍历nums时查找哈希表中是否存在target-nums[i]的元素,若存在返回对应的下标,若不存在则将nums[i]插入哈希表中。

【3】C++代码:

class Solution {
public:
    vector twoSum(vector& nums, int target) {
        unordered_map hash;
        for (int i = 0; i second, i};
            }
            hash.insert(make_pair(nums[i], i));
        }
        return {};
    }
};

【4】时间复杂度:O(N),只遍历了一次nums数组。

【5】空间复杂度:O(N),开辟了额外的哈希表空间。


四、四数相加II(LeetCode--454)

【1】题目描述:

【算法】代码随想录之哈希表(更新中)

【2】解决思想:哈希表法。首先,双循环遍历nums1和nums2,将它们相加的值保存到哈希表的first中且second为1,若它们已经存在于哈希表中则将second++。其次,双循环遍历nums3和nums4,在哈希表中寻找0-(nums3[i]+nums4[j]),若找到则将ret++。最后,返回ret。

【3】C++代码:

class Solution {
public:
    int fourSumCount(vector& nums1, vector& nums2, vector& nums3, vector& nums4) {
        //遍历数组nums1和nums2,保存相加的值和出现次数
        unordered_map hash;
        for (int a : nums1) {
            for (int b : nums2) {
                hash[a + b]++;
            }
        }
        //遍历数组nums3和nums4,查找0-相加的值是否存在于哈希表中
        int ret = 0;
        for (int c : nums3) {
            for (int d : nums4) {
                if (hash.find(0 - c - d) != hash.end()) {
                    ret += hash[0 - c - d];
                }
            }
        }
        return ret;
    }
};

【4】时间复杂度:O(N^2),采用了双循环遍历。

【5】空间复杂度:O(N^2),开辟了额外的哈希表空间。


五、三数之和(LeetCode--15)

【1】题目描述:

【算法】代码随想录之哈希表(更新中)

【2】解决思想:双指针法,而不用哈希表法(哈希表法去重较为麻烦)。首先,对nums进行从小到大的排序,那么当nums[i]大于0时后续就不可能有符合要求的三元组。其次,left指针指向i+1,right指针指向最后一个元素,在i固定时循环判定i、left、right这三个位置的元素之和是否等于0,若为0则添加到结果数组中,若>0说明太大让right--,若 0) { return ret; } //nums[i]去重 if (i > 0 && nums[i] == nums[i - 1]) { continue; } //双指针寻找符合条件的三元组 int left = i + 1, right = nums.size() - 1; while (left 0) {//大于目标 right--; } else {//小于目标 left++; } } } return ret; } };

【4】时间复杂度:O(N^2),采用了双循环遍历。

【5】空间复杂度:O(1)。


六、四数之和(LeetCode--18)

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]