【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

🤵‍♂️ 个人主页: @计算机魔术师 👨‍💻 作者简介:CSDN内容合伙人,全栈领域优质创作者。

🌐 推荐一款找工作神器网站: ​​牛客网 ​​ |笔试题库|面试经验|实习招聘内推

还没账户的小伙伴 ​​速速点击链接登录注册吧!🙋‍♂️​

@[toc]

一、说在前面

刷题是一件日积月累的事情,我们在刷题中要保持良好习惯,让每一道题发挥最大作用!以下是 某ACM🥇金牌选手所建议的刷题方式,觉得很不错,给大家参考一下

如何正确的做一道题

  1. 从简入手: 先从简单暴力(时间复杂度高)的方法入手。
  2. 优化: 思考如何在第一步的基础上,如何优化算法,降低时间复杂度。
  3. 构思代码: 有了以上两步,我们此时应该已经有了一个正确的想法,此时我们应该构思代码,有那几部分,每部分实现什么功能,代码怎么写。而不是直接闷头去写代码,没想清楚直接去写代码,会导致写了一半发现思路不对,写的代码都是错误的。
  4. 写代码: 实现第三步代码。
  5. (Debug): 如果我们的题目没有通过测试,应该检查代码是不是有bug、思路对不对等。
  6. 总结与反思: 题目通过了,我们应该总结一下这道题考察的知识点、切入的角度、同类型的题目等,同时思考有没有更优的办法。

要做到以上几点,一道题学得很透彻,遇到同类问题都可以举一反三。

[En]

To achieve the above points, a problem to learn is very thorough, encounter the same type of problems can be cited.

数组&双指针章节

二、两数之和

和​ ​hello world​​ 一样经典的刷题入门第一题 —— 两数之和

原题如下:

给定一个整 数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并>返回它们的数组下标。
您可以假设每个输入只对应一个答案。但是,数组中的相同元素不能在答案中重复。

[En]

You can assume that each input corresponds to only one answer. However, the same element in the array cannot be repeated in the answer.

您可以按任何顺序返回答案。

[En]

You can return the answers in any order.

示例 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]

提示:

2 -109 -109 只会存在一个有效答案

进阶:你可以想出一个时间复杂度小于 O(n2) 的算法吗?

思路历程:

2.1、暴力枚举

按照解题思路,暴力枚举,这里选择快速排序法,快速筛选

2.1.1 python实现

代码:

class Solution:    def twoSum(self, nums: List[int], target: int) -> List[int]:        result = []        for i in range(len(nums)):            for j in range(i+1,len(nums)):                if target == nums[i] + nums[j]:                    result.append(i)                    result.append(j)        return result

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

2.1.2 java实现

代码:

class Solution {
public int[] twoSum(int[] nums, int target) {
List<Integer> result = new ArrayList<Integer>();
for(int i=0;i<nums.length;i++){
for(int j=i+1;j<nums.length;j++){
if(target == nums[i]+nums[j])
return new int[]{i,j};
}
}
return null;
}
}

可以看出​ &#x200B;java&#x200B;​作为编译性语言还是要比python运行速度快很多,不过使用内存消耗更多一点

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

时间复杂度为&#x200B;O(n2)&#x200B;空间复杂度:​ &#x200B;O(1)&#x200B;

3.1 哈希表(Hash table)

我们使用哈希表对其进行优化。让我们简单地谈谈哈希表的原理

[En]

We apply hash table to optimize it. Let’s briefly talk about * the principle of hash table *

  • 数组的特点是寻址容易,插入和删除困难
    [En]

    Array is characterized by easy addressing and difficult insertion and deletion*

  • 链表的特点是寻址困难,容易插入和删除。
    [En]

    the linked list is characterized by difficult addressing and easy insertion and deletion.*

我们把两者结合起来,就是哈希表

[En]

We combine the two, which is * hash table *

哈希表的底层实际上是基于数组来存储的,当插入键值对时,并不是直接插入该数组中,而是通过对键进行​ &#x200B;Hash&#x200B;​​运算得到​ &#x200B;Hash&#x200B;​值,然后和数组容量取模,得到在数组中的位置后再插入(不害怕多个重复数字,使用 链表把多个数字都压缩在同一个值上)。取值时,先对指定的键求​ &#x200B;Hash&#x200B;​​值,再和容量取模得到底层数组中对应的位置,如果指定的键值与存贮的键相匹配,则返回该键值对,如果不匹配,则表示哈希表中没有对应的键值对。这样做的好处是在查找、插入、删除等操作可以做到​ &#x200B;O(1)&#x200B;​​,最坏的情况是​ &#x200B;O( n )&#x200B;​,当然这种是最极端的情况,极少遇到。

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

哈希表实现原理很多,不管哪门语言,实现一个HashMap的过程均可分为三大步骤:

  1. 实现一个Hash函数
  2. 合理解决Hash冲突
  3. 实现HashMap的操作方法

我们这里不深揪算法,大概了解即可,​ &#x200B;python&#x200B;​​的​ &#x200B;dict&#x200B;​​便是​ &#x200B;&#x54C8;&#x5E0C;&#x8868;&#x7B97;&#x6CD5;&#x200B;​,我们直接使用即可。

3.1.1 python实现

代码:

class Solution:    def twoSum(self, nums: List[int], target: int) -> List[int]:        result = []        Hashmap = dict()        for i,num in enumerate(nums):            if target - num  in Hashmap:                result.append(Hashmap[target - num])                result.append(i)            Hashmap[nums[i]] = i # 默认会把本次数值省略        return result

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

执行速度比以前快了十倍,内存消耗也多了一点。

[En]

The execution speed is ten times faster than before, and the memory consumption is a little more.

时间复杂度: ​ &#x200B;O(n)&#x200B;空间复杂度: ​ &#x200B;O(1)&#x200B;

这里有一点秒的比较,因为有一个特殊的情况。

[En]

Here is a bit of a comparison of seconds, because there is a special case.

输入:[3,2,4]6

这个时候如果正常遍历所有数,会有可能添加到​ &#x200B;3&#x200B;​​,因为 6 – 3 = 3 在​ &#x200B;nums&#x200B;​里面,即自己和自己相加了。 解决办法: 错开索引,在当前索引在字典创建对应值,跳过本次循环到下一个值判断。

3.1.2 Java实现

class Solution {
public int[] twoSum(int[] nums, int target) {
Map<Integer,Integer> hashmap = new HashMap<Integer,Integer>();
List<Integer> result = new ArrayList<Integer>();
for(int i=0;i < nums.length;i++){
if (hashmap.containsKey(target - nums[i])){
return new int[]{hashmap.get(target - nums[i]),i};
}
hashmap.put(nums[i],i);
}
return new int[0];
}
}

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

速度是以前暴力枚举的十倍,内存消耗保持不变

[En]

Ten times as fast as previous violent enumerations, memory consumption remains unchanged

到这里我们已经成功踏出我们刷题的第一步啦🎉🎉🎉

今日份推荐 —— 牛客网

学习和掌握一门语言的一个快速方法是练习这门语言的语法,并将其与其他语言进行比较,以获得更深的理解和收获!

[En]

A quick way to learn and master a language is to practice the grammar of the language and compare it with other languages to gain a deeper understanding and harvest!

如果还不知道哪里可以适用与 小白 刷题掌握语法,牛客网亲测很不错!!​​点击链接跳转牛客网登录注册​​看看,他们现在的IT题库内容很丰富,属于国内做的很好的了,而且是课程+刷题+面经+求职+讨论区分享,一站式求职学习网站,最最最重要的里面的资源全部免费!!

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

他们的​ &#x200B;Java & Python&#x200B;​​题单是从最基础的输出、字符串格式化输出开始,经过运算符、列表、循环语句、条件语句、元组、字典、函数等知识点,一步一步教你慢慢学会​ &#x200B;Java & Python&#x200B;​那为数不多的基本语法,最后再配合上8道具有实践意义的综合实践题,可以帮你更加有效的巩固前面学会的知识。

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

​牛客网​​还提供题解专区和讨论区会有大神提供题解思路,对新手玩家及其友好,有不清楚的语法,不理解的地方,看看别人的思路,别人的代码,也许就能豁然开朗。

如果现在的你按捺不住卷起来,那就赶快点击下方链接学起来吧! 链接:​点击链接跳转牛客网开始刷题之路!!!​

​如果还没有账号的小伙伴速速点击链接登录注册吧!🙋‍♂️​

Original: https://blog.51cto.com/u_15691039/5637395
Author: 计算机魔术师
Title: 【刷题之路 | Java & Python】两数之和(暴力枚举&哈希表)

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/500216/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 解析京东cookie

    该脚本会自动解析剪贴板内的cookie内容,免去手动寻找pin和key的麻烦 Original: https://www.cnblogs.com/1314h/p/16745098….

    Python 2023年6月11日
    080
  • Python数据分析摘要(1)- DataFrame数据定位,筛选和修改

    数据分析在社会和经济生活中扮演着越来越重要的角色。因此,我在接下的几篇blog中阐释比较常用的数据分析的代码,如有不妥,欢迎指正!数据分析第一个常用的库是pandas。 相比较nu…

    Python 2023年8月7日
    051
  • 数据分析 pandas and matplotlib详细学习(2)———— pandas操作excel(2022.7.14)

    又到了一天的学习了,不过今天突然想玩会游戏,玩的时候很开心,但玩完了,又后悔了,发现玩完后头还有点晕,算了算了,51次又下又卸载游戏,哈哈。不过游戏玩了,文章还是要继续更新的不然的…

    Python 2023年9月1日
    068
  • python函数的两种嵌套方法

    函数的嵌套有两种方式: 交叉嵌套 回环嵌套 交叉嵌套的方式是在本函数中调用同一级或上一级函数的嵌套方法: def func(foo): print(1) foo() print(3…

    Python 2023年11月9日
    064
  • EasyPoi大数据导入导出百万级实例

    EasyPoi介绍: 利用注解的方式简化了Excel、Word、PDF等格式的导入导出,而且是百万级数据的导入导出。EasyPoi官方网址:EasyPoi教程_V1.0 (mydo…

    Python 2023年10月16日
    0150
  • Wireshark 实验

    实验一 ipconfig 实作一 实作二 ping 实作一 实作二 tracert 实作一 实作二 ARP 实作一 实作二 实作三 DHCP 实作一 netstat 实作一 实作二…

    Python 2023年9月30日
    043
  • 贝叶斯推理三种方法:MCMC 、HMC和SBI

    对许多人来说,贝叶斯统计仍然有些陌生。因为贝叶斯统计中会有一些主观的先验,在没有测试数据的支持下了解他的理论还是有一些困难的。本文整理的是作者最近在普林斯顿的一个研讨会上做的演讲幻…

    Python 2023年8月24日
    039
  • numpy知识点记录

    np.arange(start, stop, step, dtype=None):arange函数用于创建等差数组; start:可忽略不写,默认从0开始;起始值stop:结束值;…

    Python 2023年8月27日
    049
  • 【Anaconda 故障排除】之 EnvironmentNotWritableError

    目录 前言 1 Anaconda Prompt 报错 2 IPython 报错 3 管理员身份运行 Anaconda Powershell Prompt 4 其他方法 总结 前言 …

    Python 2023年9月9日
    081
  • Python解释器路径寻找规则

    python解释器位置、常见优化 Python编辑器路径寻址总结 *Python寻找解释器顺序 Python 编程优化 群演1号 run.sh #!/usr/bin bash . …

    Python 2023年10月21日
    042
  • Python:opencv画点、圆、线、多边形、矩形

    简介:机器学习视觉方向一般都需要在图像中添加标注框,标注框有着很大的用处,特别是对图像中某些需要关注的特征起到圈定的效果,方便对特征选择进行处理。 相关攻略: 机器学习:基本流程P…

    Python 2023年8月3日
    0112
  • python能处理csv文件吗_python处理csv文件非常慢

    因此,我尝试打开一个csv文件,读取它的字段,并基于此修复其他一些字段,然后将数据保存回csv。我的问题是csv文件有200万行。最好的方法是什么来加快速度。 csv文件包括 ID…

    Python 2023年8月22日
    058
  • Nginx和uWSGI和Flask的关系

    1、uWSGI uWSGI是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。要注意…

    Python 2023年8月10日
    043
  • pyspark 读取本地csv_pyspark 读取csv文件创建DataFrame的两种方法

    pyspark 读取csv文件创建DataFrame的两种方法 方法一:用pandas辅助 from pyspark import SparkContext from pyspar…

    Python 2023年8月7日
    049
  • 一文搞懂ubuntu下colmap的使用方法

    本文介绍了基于ubuntu20.04下colmap的两种使用方法,新手向,如有不对请指教,因为colmap的安装编译网络上有很多教程,并且很容易操作,这里不再赘述。本博客的大部分内…

    Python 2023年9月26日
    054
  • 企业项目

    企业的web项目类型 企业项目开发流程 企业的web项目类型 商城 B2C 直销商城 商家与会员直接交易 ( Business To Customer ) B2B 批发商城 商家与…

    Python 2023年6月12日
    088
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球