Java查找不重復(fù)無序數(shù)組中是否存在兩個數(shù)字的和為某個值
今天去某在線教育面試面試官讓做的一道題,題目描述如下:
- 給定一個不重復(fù)的無序數(shù)組arr和一個定值num
- 查找arr中是否有兩個數(shù)的和等于num
- 有則返回這兩個數(shù)的下標(biāo)(可能有多組, 只用返回一組), 沒有則返回null
很多人一想可能就是兩層for循環(huán),我想了很久最后寫了雙重for循環(huán)…【這個代碼太easy就不放了】然后面試官說知道哈希嗎,由于哈希查找的時間復(fù)雜度是O(1),從哈希的角度去考慮,這中間還有一堆就不描述了,說一下怎么用哈希實現(xiàn)。
實現(xiàn)思路:
將數(shù)組中的所有的值放入HashMap的Key中,Value存放該值對應(yīng)的下標(biāo),遍歷這個HashMap,取得Key,計算如果可以和這個Key加起來的和為num的值,如果這個值存在,就直接返回這兩個下標(biāo)。遍歷一次的時間復(fù)雜度為O(N),查找的時間復(fù)雜度是O(1),總體時間復(fù)雜度O(N)。
代碼實現(xiàn):
public class getTwoNumsSumEquals {
public static void main(String[] args) {
int[] arr = new int[]{3, 4, 6, 5, 9, 8};
int num = 8;
int[] ret = getIndex(arr, num);
System.out.println("index of two numbers R:" + ret[0] + " " + ret[1]);
}
// 找到這兩個數(shù)的下標(biāo)并返回(以長度為2的數(shù)組的形式返回)
private static int[] getIndex(int[] arr, int num) {
int[] ret = new int[2];
HashMap<Integer, Integer> hashMap = new HashMap<>();
int index = 0;
// 將每個數(shù)字和其下標(biāo)放進map中
for (Integer curr : arr) {
hashMap.put(curr, index++);
}
// 遍歷HashMap并判斷
for (Map.Entry<Integer, Integer> entry : hashMap.entrySet()) {
int value = entry.getKey();
int subValue = num - value;
if(hashMap.containsKey(subValue)) {
// 找到啦!
ret[0] = entry.getValue();
ret[1] = hashMap.get(subValue);
break;
}
}
return ret;
}
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
springboot登錄攔截器+ThreadLocal實現(xiàn)用戶信息存儲的實例代碼
ThreadLocal 為變量在每個線程中創(chuàng)建了一個副本,這樣每個線程都可以訪問自己內(nèi)部的副本變量,這篇文章主要介紹了springboot登錄攔截器+ThreadLocal實現(xiàn)用戶信息存儲的實例代碼,需要的朋友可以參考下2024-03-03
使用Spring Boot Mybatis 搞反向工程的步驟
這篇文章主要介紹了使用Spring Boot Mybatis 搞反向工程的步驟,幫助大家更好的理解和使用spring boot框架,感興趣的朋友可以了解下2021-01-01
Java如何獲取當(dāng)前進程ID以及所有Java進程的進程ID
本篇文章主要介紹了Java如何獲取當(dāng)前進程ID以及所有Java進程的進程ID,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
Java 高并發(fā)九:鎖的優(yōu)化和注意事項詳解
本文主要介紹Java高并發(fā)鎖的優(yōu)化和注意事項,這里整理了詳細(xì)的資料,并講解了 1. 鎖優(yōu)化的思路和方法 2. 虛擬機內(nèi)的鎖優(yōu)化 3. 一個錯誤使用鎖的案例 4. ThreadLocal及其源碼分析等知識,有需要的小伙伴可以參考下2016-09-09
Java中ThreadLocal使用原理及Synchronized區(qū)別
ThreadLocal叫做線程變量,本文詳細(xì)的介紹了ThreadLocal使用原理及Synchronized區(qū)別,有需要的朋友可以參考一下,希望對你有所幫助。2023-05-05
解決RestTemplate加@Autowired注入不了的問題
這篇文章主要介紹了解決RestTemplate加@Autowired注入不了的問題,具有很好的參考價值,希望對大家有所幫助。2021-08-08

