当前位置:网站首页>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.
边栏推荐
- excel写入不完全sheet.append方法(openpyxl)
- VsCode preview Geojson data
- fatal error: jni.h: No such file or directory
- 【WPS-OFFICE-Word】 WPS中样式的运作原理?样式自动更新、自动改变如何处理?样式的管理方法?
- PreFixSum前缀和
- Difference差分数组
- ctfshow php特性
- 【HCIP】MPLS实验
- ImportError: /lib/libgdal.so.26: undefined symbol: sqlite3_column_table_name
- Execute the mysql script file in the docker mysql container and solve the garbled characters
猜你喜欢
字节跳动三面拿offer:网络+IO+redis+JVM+GC+红黑树+数据结构,助你快速进大厂!!
阿里巴巴政委体系-第六章、阿里政委体系运作
Difference差分数组
[笔记]机器学习之前言介绍
Alibaba senior experts create a learning architecture from scratch, including Alibaba's internal technology stack PPT, PFD actual combat
Higher mathematics - chapter ten infinite series - constant term series
如何理解即时通讯开发移动网络的“弱”和“慢”
要想成为黑客,离不开这十大基础知识
pytest接口自动化测试框架 | Jenkins集成初探
[Notes] Introduction to machine learning
随机推荐
[Dataset][VOC] Rat dataset voc format 3001 sheets
Shell编程案例
PreFixSum前缀和
学弟:我适不适合转行做软件测试?
Postgresql源码(64)查询执行——子模块Executor(2)执行前的数据结构和执行过程
Web项目Controller统一返回实体类
PHP基础笔记-NO.1
Bytes to beat three sides take offer: network + GC + + IO + redis + JVM red-black tree + data structure, to help you quickly into the giant!!!!!
MySQL读写分离的三种实现方案
Radondb mysql installation problems
七夕之前,终于整出了带AI的美丽秘笈
Postgresql-xl全局快照与GTM代码走读(支线)
Redis:哨兵
剑指Offer 56.数组中数字出现的次数
MPLS的简单应用于实验
云图说丨初识华为云微服务引擎CSE
红日安全内网渗透靶场-VulnStack-1
VsCode preview Geojson data
LineSegmentTree线段树
warnings.warn(“Title is more than 31 characters. Some applications may not be able to read the file