LeetCode 热题 100 | 哈希

这篇具有很好参考价值的文章主要介绍了LeetCode 热题 100 | 哈希。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1  基础知识

1.1  定义哈希表

1.2  遍历哈希表

1.3  查找某一个键

1.4  插入键值对

1.5  获取键值对的值

1.6  搜索功能

2  三道题

2.1  1. 两数之和

2.2  49. 字母异位词分组

2.3  128. 最长连续序列


菜鸟做题第一周,语言是 C++

1  基础知识

1.1  定义哈希表
unordered_map<string, vector<string>> hashtable;
  • unordered_map 用于定义哈希表
  • 第一个参数为 key 的数据类型,这里是 string 类型
  • 第二个参数为 value 的数据类型,这里是 vector<string> 类型
1.2  遍历哈希表
for (auto str:hashtable) {
    // code
}
  • 这种遍历方法对其他容器也适用
  • 冒号后写遍历的对象,这里是 hashtable
  • 冒号前写被遍历到的元素,这里取名为 str
1.3  查找某一个键
auto it = hashtable.find(target);
if (it != hashtable.end()) {
    // code
}
  • find() 的参数是想要查找的 key
  • it 是本次查找的结果
  • 若没有找到,则 it 等于 hashtable.end()
  • hashtable.end() 是哈希表最后一个元素的后一位
1.4  插入键值对
// 方法一
hashtable[key] = value;
// 方法二
hashtable[key].push_back(value);
  • 目前看到过上述两种方法
  • key 处填写键,value 处填写值

这是看人下碟,暂时还不太懂

1.5  获取键值对的值
// 方法一
str->second
// 方法二
str.second
  • 同样看到过两种方法
  • str 是哈希表中的某一键值对
  • second 代表想要获取的是 value
1.6  搜索功能

作用:搜索某个键是否存在于哈希表内。

hashtable.count(key)
  • count 的作用是搜索而不是计数
  • key 代表想要搜索的键
  • 若存在该键,则返回值为 1

2  三道题

2.1  1. 两数之和

解题思路:

  1. 遍历数字集合 nums
  2. 查询是否有和为 target 的另一个数字

思路说明图:

  • 这里假设 target=9
  • 将暂时没找到伴儿的数字放入哈希表中

LeetCode 热题 100 | 哈希,力扣,哈希算法,leetcode,算法

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int, int> hashmap;
        for (int i = 0; i < nums.size(); ++i) {
            auto it = hashmap.find(target - nums[i]);
            if (it != hashmap.end()) {
                return {i, it->second};
            }
            hashmap[nums[i]] = i;
        }
        return {};
    }
};

可能出现的问题:

LeetCode 热题 100 | 哈希,力扣,哈希算法,leetcode,算法

虽然题设表明一定能找到一对和为 target 的数字,但力扣比较严谨,它要求 if 判断结构中的 else 情况也要进行返回(虽然用不到)。

2.2  49. 字母异位词分组

解题思路:

  1. 遍历 strs 中的每一个字符串
  2. 使用 sort 函数对这些字符串进行重新排序
  3. 排序前的字符串作为 key,排序后的字符串作为 value,插入到哈希表中
  4. 哈希表中每个键值对的 value 的集合即为最终的结果
class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        vector<vector<string>> result;
        unordered_map<string, vector<string>> hashtable;
        for (auto str:strs) {
            auto temp = str;
            sort(temp.begin(), temp.end());
            hashtable[temp].push_back(str);
        }
        for (auto str:hashtable) {
            result.push_back(str.second);
        }
        return result;
    }
};

这个涉及到哈希表的原理,即 key 相同时,如何存储不同的 value,暂时还没看

2.3  128. 最长连续序列

解题思路:

  1. 遍历 nums 寻找可能成为序列头的数字(不能存在 num - 1)
  2. 若找到可能成为序列头的数字,则顺着它找序列并计数(哈希表找 num + 1)
  3. 每计数完一条序列的长度都要和之前序列的长度进行比较(cucount 和 count)
  4. 返回最长的长度(count)

思路说明图:

LeetCode 热题 100 | 哈希,力扣,哈希算法,leetcode,算法

思考过程:

一开始想的是找序列中最小的那个数字(我理所应当地认为它就是序列头),然后以它为开头去找序列并计数,但 nums 中可能存在不止一条连续序列,因此我们需要考虑所有可能的序列头。

class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        if (nums.size() == 0) return 0;

        int count = 1;
        unordered_map<int, int> hashmap;
        for (int i = 0; i < nums.size(); ++i) {
            hashmap[nums[i]] = i;
        }
        for (auto num:nums) {
            auto it = hashmap.find(num - 1);
            if (it == hashmap.end()) {
                int cucount = 1;
                it = hashmap.find(num + cucount);
                while (it != hashmap.end()) {
                    ++cucount;
                    it = hashmap.find(num + cucount);
                }
                count = max(count, cucount);
            }
        }
        return count;
    }
};

哈希表并不是最优解,因为貌似用不到 value,但我目前只会哈希表。。。文章来源地址https://www.toymoban.com/news/detail-800556.html

到了这里,关于LeetCode 热题 100 | 哈希的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • LeetCode热题100——链表

    LeetCode热题100——链表

    给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回

    2024年02月05日
    浏览(9)
  • LeetCode 热题 100 | 链表(上)

    LeetCode 热题 100 | 链表(上)

    目录 1  基础知识 1.1  空指针 1.2  结构体 1.3  指针访问 1.4  三目运算符 2  160. 相交链表 3  206. 反转链表 4  234. 回文链表 菜鸟做题第三周,语言是 C++ 1  基础知识 1.1  空指针 使用 nullptr 来判断是否为空指针: “NULL 在 C++ 中就是 0,这是因为在 C++ 中 void* 类型是不允许隐式

    2024年02月19日
    浏览(11)
  • Leetcode热题100

    暴力:{i,j}直接返回vectorint 哈希表: map: 红黑树 具有自动排序的功能,是非严格的二叉搜索树。map内部的所有元素都是有序的,使用中序遍历可将键值按照从小到大遍历出来。插入的时间是O(logn),查询时间是O(logn)。可以支持所有类型的键值对 unordered_map: 哈希表(也叫散列表

    2024年02月14日
    浏览(9)
  • 螺旋矩阵 LeetCode热题100

    给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。 模拟,朝一个方向走,走过的点标记一下,直到碰到边界或碰到已经走过的路,换个方向。右-下,下-左,左-上,上-右。直到走完所有点。

    2024年02月14日
    浏览(13)
  • LeetCode热题 100整理

    LeetCode热题 100整理

    35. 搜索插入位置 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums = [1,3,5,6], target = 5 输出: 2 示例 2: 输入: nums = [1,3,5,6], target

    2024年02月13日
    浏览(9)
  • LeetCode 热题 HOT 100

    LeetCode 热题 HOT 100

    重点是当有一个链表为空了不单独处理,按节点为0处理。 滑动窗口! 首先要判断slow需不需要更新,怎么判断?slow = max(umap[s[fast]], slow);什么意思,就是说:**umap[s[fast]]的意义是,为了在slow和fast之间不出现重复字符,slow能处于的最左位置。**如图,当j第一次到d,将umap[s[j

    2024年02月07日
    浏览(10)
  • leetcode热题100.两数之和

    给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。 你可以按任意顺序返回答案。 示例 1: 输入:nums =

    2024年01月16日
    浏览(8)
  • LeetCode 热题 100 | 二叉树(中下)

    LeetCode 热题 100 | 二叉树(中下)

    目录 1  基础知识 1.1  队列 queue 1.2  栈 stack 1.3  常用数据结构 1.4  排序 2  98. 验证二叉搜索树 3  230. 二叉搜索树中第 K 小的元素 4  199. 二叉树的右视图 菜鸟做题忘了第几周,躺平过了个年TT 1  基础知识 1.1  队列 queue queuetype q:定义一个参数类型为 type 的队列 q.push(varia

    2024年02月21日
    浏览(7)
  • 【LeetCode热题100】【矩阵】螺旋矩阵

    【LeetCode热题100】【矩阵】螺旋矩阵

    题目链接:54. 螺旋矩阵 - 力扣(LeetCode) 先走外面的圈再走里面的圈,可以用递归来解决,对于要走的一个圈,由四个角决定,其实是三个数,(0,0),(0,n),(m,0),(m,n),每次先从左上角走到右上角,再走到右下角,再走到左下角,再走回来 对于后面两个的往

    2024年04月16日
    浏览(11)
  • LeetCode 热题 100 | 动态规划(一)

    LeetCode 热题 100 | 动态规划(一)

    目录 1  70. 爬楼梯 1.1  基本思路 1.2  官方题解 2  118. 杨辉三角 3  198. 打家劫舍 菜鸟做题,语言是 C++ 1  70. 爬楼梯 核心思想:把总问题拆解为若干子问题。 总问题:上到 5 楼的方式有多少种 子问题:上到 4 楼的方式有多少种、上到 3 楼的方式有多少种 总问题 = 子问题 1

    2024年04月17日
    浏览(8)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包