博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用HashMap将两个嵌套循环拆成一个单循环
阅读量:5039 次
发布时间:2019-06-12

本文共 686 字,大约阅读时间需要 2 分钟。

题目:给出一个整数数组和一个目标值target,从数组中找出两个元素,使这两者之和为目标值target,返回数组中这两个元素的序号。(假设target必有解,每个数组元素只用一次)

例如:int[] nums={2,7,11,15} , target=9
则返回数组中序号 [0,1]

题目源自Leetcode

答案1:最简单粗暴的答案,优化度为O(n2)

class Solution{  public int[] twoSum(int[] nums,int target){ for (int i=0;i

答案2:通过HashMap将嵌套循环拆成两个单for循环

class Solution {  public int[] twoSum(int[] nums, int target){ Map
map=new HashMap<>(); for(int i=0;i

最优答案:一个for循环,因为要计算的 target 有两个元素(两次机会),第一个正确的元素肯定不成功会被保存到map中,到第二个正确元素可以读取到。

class Solution {    public int[] twoSum(int[] nums, int target){ Map map=new HashMap(); for(int i=0;i

转载链接:https://www.jianshu.com/p/e8cbe28c99b7

转载于:https://www.cnblogs.com/open-source-java/p/10966279.html

你可能感兴趣的文章
http初探
查看>>
elasticsearch的安装
查看>>
__next__()
查看>>
爬取:中国大学排名
查看>>
聊天室(C++客户端+Pyhton服务器)_1.框架搭设
查看>>
UpdatePanel 内控件 更新“外的”控件【转】
查看>>
mybatis中&gt;=和&lt;=的实现方式
查看>>
Python面向对象03/继承
查看>>
java序列化和反序列化
查看>>
绝对定位
查看>>
flink源码编译(windows环境)
查看>>
dpkg 删除 百度网盘 程序
查看>>
服务器nginx安装
查看>>
std::nothrow
查看>>
rest-framework 分页器
查看>>
JQuery(一)安装&选择器 样式篇
查看>>
浏览器的DNS缓存查看和清除
查看>>
浏览器跨域问题
查看>>
HTML5 input控件 placeholder属性
查看>>
使用JAVA如何对图片进行格式检查以及安全检查处理
查看>>