当前位置:网站首页>Force is brushed buckle problem for the sum of two Numbers
Force is brushed buckle problem for the sum of two Numbers
2022-08-03 19:04:00 【Lanzhou Qianfan】
The Sum of Two Numbers
This question is the first question of Likou, and it is the place where the dream of brushing questions begins.It must not be underestimated, because I am very disheveled.
The title is as follows:
Given an integer array nums and an integer target value target, please find the two integers in the array that are the target value target and return their array indices.You can assume that there will only be one answer for each input.However, the same element in the array cannot be repeated in the answer.You can return answers in any order.
The requirements of the title are given an array, given a target value, and then let you find the sum of two values in the array equal to the target value, and then return their subscripts.
Normally we don't find the target data so quickly.There is usually a traversal process.A move index is added to the following value.Similar to this.Know to find the target value.
Such code is implemented like this.
for (int i = 0; i < nums.length; i++) {for (int i1=i+1; i1 < nums.length; i1++) {if(nums[i]+nums[i1]==target){arr[0]= i;arr[1]=i1;}}}
According to this logic, we still use a double for loop. When looking for the target value, we will traverse to the elements that have been traversed before, which is repetition.
For example, 2+7 2+11 2+15 ··· Then we still go through 11, 15 when adding 7 and the following numbers.In this way, with the traversal of the number of searches and the increase in the amount of data, it is inevitably a waste of time and efficiency.
So we try to solve the problem in this way. After we can traverse this element again, we will write it down, and then we will not use it directly next time, which is great.And can correspond to values and subscripts.Now here is the initialization, the arrow is the traversal index move.
At the beginning, we start with 4. The difference between 4 and the target value is 16. There must be no hashmap, so we put 4 and its index into it.
Then continue, when we get here, we go to 7 to find 13, and find that there is just this key in the map, so we just return the vaue corresponding to this key, and the value is the index.Of course, you can do it the other way around.
Think about it, if we still use brute force exhaustion, then is it still a for loop when we reach 7, then it is 4+6 4+7 … 4+13 …
6+13 6+8 … 13+8 13+7 In this way, we have repeated the traversal value. From this small amount of calculation, we can find that we have used 13 5 times in total, and if we use hashmap,We just pass it once, record it, and then we can find it directly later.Is it very convenient.Implementation code
HashMap map = new HashMap<>();for (int i = 0; i < nums.length; i++) {int result = target-nums[i];if(map.containsKey(result)){map.get(result);arr[1]=i;arr[0]=map.get(result);}else {map.put(nums[i],i);}}
This efficiency is very high.
Simpleness is one thing, but it is another matter whether the simple questions can be well understood.Simple questions do not have a higher pass rate than difficult questions.
Sometimes the understanding of knowledge is temporarily understood. If the algorithm foundation is not solid, it will be forgotten immediately, and then it will fall into doubt again.Algorithms are based on data structures plus basic grammar knowledge.
边栏推荐
猜你喜欢
随机推荐
Intelligent security contract - delegatecall (2)
ctfshow php特性
Oracle 脚本实现简单的审计功能
力扣刷题之分数加减运算(每日一题7/27)
阿里巴巴政委体系-第六章、阿里政委体系运作
With the help of Kubernetes kubekey speed installation
分享即时通讯开发之WebSocket:概念、原理、易错常识、动手实践
OSError: [WinError 123] 文件名、目录名或卷标语法不正确
阿里资深架构师钟华曰:中台战略思想与架构实战;含内部实施手册
WEB 渗透之RCE
梅科尔工作室-14天华为培训六
谷歌浏览器安装插件教程步骤,开发用这2个插件工作效率倍增
机器学习的方法总结
SQL server 实现触发器备份表数据
ROS仿真环境搭建
cocos creater 3.x 插件安装方法
Shell:循环语句
阿里资深专家打造从零开始学架构,含阿里内部技术栈PPT、PFD实战
红日安全内网渗透靶场-VulnStack-1
关于2022年度深圳市技术攻关重大项目的申报通知