【算法】LeetCode算法题-Two Sum
程序 = 数据结构 + 算法。
算法是每一位程序员学习成长之路上无法避开的重要一环,并且越早接触越好。今后会每天做些算法题,至少每天做一道题目,同时会记录自己的解题思路和代码,通过【算法】专题来分享。针对数据结构这一块的知识,我也会抽时间补习,毕竟不是科班出生,从长远看,数据结构与算法学的越早越扎实越好,不管你使用的是哪一种开发语言。
01 看题和准备
给定一个整数数组和一个目标整数,该目标整数满足数组中两元素之和,返回数组中两个数字的下标索引,以数组形式表示结果。例如给定数组int[] nums = [2, 7, 11, 15],目标整数int target = 9,因为 nums[0] + nums[1] = 2 + 7 = 9,返回包含两数索引的数组[0, 1]。
本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。
02 分析题目
这道题目求的是数组内任意两元素之和等于给定的目标整数,于是很容易想到数组for循环遍历,并且是两层for循环,于是第一版的代码思路已经有了。
public int[] twoSum(int[] nums, int target) {
    int[] result = new int[2];
    if (nums.length < 2) {
        return null;
    }
    try {
        for (int i=0; i<nums.length; i++) {
            for (int j=i+1; j<nums.length; j++) {
                if (nums[i] + nums[j] == target) {
                    result[0] = i;
                    result[1] = j;
                }
            }
        }
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
    return result;
}
03 是否还可以优化?
上面的解法是两层循环,循环次数是n*(n-1)次,n为数组元素个数,n越大,程序执行的时间越长,那能不能只循环一次?既然可以做加法匹配,那做减法呢?先拿到目标整数与数组中每位元素的差值,再去判断此差值是否存在于此数组中。这时,我们需要一个存新数据的集合,既包含每位元素,也包含每位元素的索引,对此选取Map作为存放新数据的对象。
public int[] twoSum2(int[] nums, int target) {
    int[] result = new int[2];
    if (nums.length < 2) {
        return null;
    }
    try {
        Map<Integer, Integer> map = new HashMap<>();
        for (int k=0; k<nums.length; k++) {
            int num = target - nums[k];
            if (map.containsKey(num)) {
                result[0] = map.get(num);
                result[1] = k;
            }
            map.put(nums[k], k);
        }
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
    return result;
}
第二版的解法只用了一层循环,对比第一版解法,从时间花费上看,第二版的解法是优于第一版的。
04 小结
本篇只是作为一个开题,后续会将其他算法题按照上面的格式分享给大家,如果有什么好的解法、建议或者其他问题,可以下方留言交流!

本文首发于我的个人公众号:悦乐书,转载请注明出处!
【算法】LeetCode算法题-Two Sum的更多相关文章
- 乘风破浪:LeetCode真题_040_Combination Sum II
		乘风破浪:LeetCode真题_040_Combination Sum II 一.前言 这次和上次的区别是元素不能重复使用了,这也简单,每一次去掉使用过的元素即可. 二.Combination Sum ... 
- 乘风破浪:LeetCode真题_039_Combination Sum
		乘风破浪:LeetCode真题_039_Combination Sum 一.前言 这一道题又是集合上面的问题,可以重复使用数字,来求得几个数之和等于目标. 二.Combination Sum ... 
- (算法)LeetCode刷题
		LeetCode 56 合并区别 Given [1,3],[2,6],[8,10],[15,18], return [1,6],[8,10],[15,18]. 关键就是a[1]>=b[0] 也就 ... 
- leetcode第一题--two sum
		Problem:Given an array of integers, find two numbers such that they add up to a specific target numb ... 
- LeetCode第一题—— Two Sum(寻找两数,要求和为target)
		题目描述: Given an array of integers, return indices of the two numbers such that they add up to a speci ... 
- LeetCode算法题-Two Sum IV - Input is a BST(Java实现)
		这是悦乐书的第280次更新,第296篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第148题(顺位题号是653).给定二进制搜索树和目标数,如果BST中存在两个元素,使得 ... 
- LeetCode算法题-Path Sum III(Java实现)
		这是悦乐书的第227次更新 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第94题(顺位题号是437).您将获得一个二叉树,其中每个节点都包含一个整数值.找到与给定值相加的路径数 ... 
- LeetCode算法题-Sum of Left Leaves(Java实现)
		这是悦乐书的第217次更新,第230篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第85题(顺位题号是404).找到给定二叉树中所有左叶的总和.例如: 二叉树中有两个左叶 ... 
- LeetCode算法题-Sum of Two Integers(Java实现)
		这是悦乐书的第210次更新,第222篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第78题(顺位题号是371).计算两个整数a和b的总和,但不允许使用运算符+和 - .例 ... 
- LeetCode算法题-Range Sum Query Immutable(Java实现)
		这是悦乐书的第204次更新,第214篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第70题(顺位题号是303).给定整数数组nums,找到索引i和j(i≤j)之间的元素之 ... 
随机推荐
- Linux C 实现一个简单的线程池
			线程池的定义 线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务.线程池线程都是后台线程.每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中.如 ... 
- 在Windows 10中使用内置的SSH Client连接远程的Linux虚拟机
			无意中发现这个功能.一直以来,在Windows平台上面要通过SSH连接Linux都需要借助第三方工具,而且往往还不是很方便.但其实在去年12月份的更新中,已经包含了一个beta版本的SSH Clien ... 
- Thinkphp  table doesn't exist
			系统采用Tp3.2的改造....集群为Mysql双工模式:平时M()主要是操作写,MS操作读...今天在查询 $res =MS("user u")->join("{ ... 
- JavaScript中的三种弹窗
			---恢复内容开始--- 1.警告窗口(alert) <script type="text/javascript"> alert("我是警告弹框!" ... 
- IO学习一(File类)
			File类 1.凡是与输入.输出相关的类.接口都定义在java.io包下 2.File有构造器来创建对象,此对象对应着一个文件或文件目录 支持文件类型:.txt .avi .doc .jpg .ppt ... 
- BZOJ 1188: [HNOI2007]分裂游戏(multi-nim)
			Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1386 Solved: 840[Submit][Status][Discuss] Descripti ... 
- 洛谷P4591 [TJOI2018]碱基序列(hash dp)
			题意 题目链接 Sol \(f[i][j]\)表示匹配到第\(i\)个串,当前在主串的第\(j\)个位置 转移的时候判断一下是否可行就行了.随便一个能搞字符串匹配的算法都能过 复杂度\(O(|S| K ... 
- Activiti实现流程自由跳转
			import org.activiti.engine.ProcessEngine; import org.activiti.engine.TaskService; import org.activit ... 
- SD: 关于价格过程的确定
			在SD模块中,定价过程是一个非常重要的功能,在单据中使用哪个定价过程取决于三个因素 1)销售区域(sale Area) 该数据来自Sold-to Party的客户维护的销售数据. 2)客户主数据的定价 ... 
- Linux查看机器的硬件信息
			转载:https://linux.cn/article-9932-1.html 
