| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 力扣LeetCode 热题HOT 100 #1(两数之和) -> 正文阅读 |
|
[数据结构与算法]力扣LeetCode 热题HOT 100 #1(两数之和) |
题目:给定一个整数数组 nums?和一个整数目标值 target,请你在该数组中找出 和为目标值 target??的那?两个?整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。 你可以按任意顺序返回答案。 示例 1:输入:nums = [2,7,11,15], target = 9 示例 2:输入:nums = [3,2,4], target = 6 示例 3:输入:nums = [3,3], target = 6 提示: 2 <= nums.length <= 104 根据题目描述,此题是非常简单的 题解1:暴力枚举无for循环版(不推荐)非常冗余,但是能帮助理解原理
num1和num2是列表索引,分别从 0和1开始,每轮循环来逐一遍历列表并验证一次当前的整数相加是否为target 有for循环版(推荐)也是官方题解了
?同理 缺点: 暴力枚举时间复杂度比较高,此题中是O(n^2),所以随着列表的扩大,只会让你等待计算机算出答案的时间越来越长 题解2:哈希表(散列表)原理: 数据结构 Hash表(哈希表)_积跬步 至千里-CSDN博客_哈希表 (24条消息) hash算法原理详解_至道-CSDN博客_hash算法 (24条消息) hash算法详解_xu_dongdong的博客-CSDN博客_hash算法详解 (24条消息) 浅谈算法和数据结构:哈希表_一个程序猿的故事-CSDN博客_数据结构算法哈希 在Python中已经实现了,它就是字典 由于哈希表的特性,我们可以使用key-value来解决时间复杂度过高的问题
首先创建一个 h 字典,用 enumerate 方法给 nums 列表创建索引与列表元素的一一对应,每论循环拿出一个索引 i,列表元素 num,然后判断 target - num 这个 key 是否存在于字典中,找到就直接返回,找不到就将目前的 num 作为 key,i 作为 value 来添加入 h 字典中,直到最终找到答案返回。 之所以能这样编写代码就是利用了 10 - 2 = 8,10 - 8 = 2 这种简单的想法,要找的数没有先后之分只要差值存在于字典的 key 当中,就能用 O(1) 的时间复杂度将其找到并把对应的 value 找出来。 此代码算上for循环,总体时间复杂度只有O(n),大大提高了效率,是此题的最优解 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 18:19:57- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |