LeetCode题解——哈希表篇

导读:本篇文章讲解 LeetCode题解——哈希表篇,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

目录

一、13.罗马数字转整数

二、1.两数之和


一、13.罗马数字转整数

题目

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。

字符          数值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000
例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做  XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。 
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
给定一个罗马数字,将其转换成整数。

示例 1:

输入: s = “III”
输出: 3
示例 2:

输入: s = “IV”
输出: 4
示例 3:

输入: s = “IX”
输出: 9
示例 4:

输入: s = “LVIII”
输出: 58
解释: L = 50, V= 5, III = 3.
示例 5:

输入: s = “MCMXCIV”
输出: 1994
解释: M = 1000, CM = 900, XC = 90, IV = 4.

思路

        首先, 每个字符对应一个数值,很容易能想到使用哈希表来进行解题,然后将字符串从右往左读,读到一个字母就加上对应的数值,但是要小心特殊情况,也就是左边字母大于右边字母的情况,当发现左边字母大于右边字母时,我们选择减去对应数值。这就是我大概的解题思路,接下来就是代码实现。

 python代码

class Solution:
    def romanToInt(self, s: str) -> int:
        dict = {'I':1, 'V':5, 'X':10, 'L':50, 'C':100, 'D':500, 'M':1000}    # 一一对应
        max = 1
        sum = 0
        for ch in s[::-1]:    # 先逆序
            num = dict[ch]
            if num >= max:    # 大于等于则相加
                sum += num
                max = num     # 使用max来标记大小
            else:
                sum -= num    # 小于则相减
        return sum

这样的思路应该还算比较清晰,C语言的解法类似,在此先不给出。


二、1.两数之和

题目

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target  的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

示例 1:

输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。
示例 2:

输入:nums = [3,2,4], target = 6
输出:[1,2]
示例 3:

输入:nums = [3,3], target = 6
输出:[0,1]

 思路1

        首先想到的是暴力破解,用两层for循环,一遍一遍地去找,不过这样时间复杂度较高,虽然能过,但是耗时较长,代码如下:

python代码 

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        n = len(nums)
        for i in range(n):
            for j in range(i + 1, n):
                if nums[i] + nums[j] == target:    # 就是一遍一遍地去找,思路比较清晰
                    return[i, j]


        return[]

思路2

        在看到其他人的题解之后,学到了另一种简单的解法,使用哈希表来解题。基本思路就是把数值以及下标形成哈希表,然后到下一个元素时,如果哈希表里有这个元素,就输出下标,没有的话,就放入哈希表中。

python代码

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        hash = dict()    # 声明一个字典
        for i, num in enumerate(nums):    # 使用enumerate()函数来遍历同时返回索引
            if target - num in hash:    # 如果在哈希表里找到,就返回下标
                return [hash[target - num], i]
            hash[nums[i]] = i    # 如果没找到,就放入哈希表中
        return []

 应该重点掌握第二种解法,第一种解法太慢了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/82424.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!