代碼隨想錄--哈希表--兩數之和

題目

給定一個整數數組 nums 和一個目標值 target,請你在該數組中找出和為目標值的那 兩個 整數,并返回他們的數組下標。

你可以假設每種輸入只會對應一個答案。但是,數組中同一個元素不能使用兩遍。

示例:

給定 nums = [2, 7, 11, 15], target = 9

因為 nums[0] + nums[1] = 2 + 7 = 9

所以返回 [0, 1]

思路

暴力的解法是兩層for循環查找,時間復雜度是O(n^2)。
public class Solution {
public int[] twoSum(int[] nums, int target) {
for (int i = 0; i < nums.length; i++) {
for (int j = i + 1; j < nums.length; j++) {
if (nums[i] + nums[j] == target) {
return new int[] {i, j};
}
}
}
// 按照題目描述,這里不會運行到,因為總是會有一個解
throw new IllegalArgumentException(“No two sum solution”);
}

public static void main(String[] args) {Solution solution = new Solution();int[] nums = {2, 7, 11, 15};int target = 9;int[] result = solution.twoSum(nums, target);System.out.println("Indices: [" + result[0] + ", " + result[1] + "]");
}

}
當我們需要查詢一個元素是否出現過,或者一個元素是否在集合里的時候,就要第一時間想到哈希法。

需要使用 key value結構來存放,key來存元素,value來存下標,那么使用map正合適。
在這里插入圖片描述在這里插入圖片描述C++代碼:

class Solution {
public:
vector twoSum(vector& nums, int target) {
std::unordered_map <int,int> map;
for(int i = 0; i < nums.size(); i++) {
// 遍歷當前元素,并在map中尋找是否有匹配的key
auto iter = map.find(target - nums[i]);
if(iter != map.end()) {
return {iter->second, i};
}
// 如果沒找到匹配對,就把訪問過的元素和下標加入到map中
map.insert(pair<int, int>(nums[i], i));
}
return {};
}
};

時間復雜度: O(n)
空間復雜度: O(n)

Java

//使用哈希表
public int[] twoSum(int[] nums, int target) {
int[] res = new int[2];
if(nums == null || nums.length == 0){
return res;
}
Map<Integer, Integer> map = new HashMap<>();
for(int i = 0; i < nums.length; i++){
int temp = target - nums[i]; // 遍歷當前元素,并在map中尋找是否有匹配的key
if(map.containsKey(temp)){
res[1] = i;
res[0] = map.get(temp);
break;
}
map.put(nums[i], i); // 如果沒找到匹配對,就把訪問過的元素和下標加入到map中
}
return res;
}

//使用雙指針
public int[] twoSum(int[] nums, int target) {
int m=0,n=0,k,board=0;
int[] res=new int[2];
int[] tmp1=new int[nums.length];
//備份原本下標的nums數組
System.arraycopy(nums,0,tmp1,0,nums.length);
//將nums排序
Arrays.sort(nums);
//雙指針
for(int i=0,j=nums.length-1;i<j;){
if(nums[i]+nums[j]<target)
i++;
else if(nums[i]+nums[j]>target)
j–;
else if(nums[i]+nums[j]==target){
m=i;
n=j;
break;
}
}
//找到nums[m]在tmp1數組中的下標
for(k=0;k<nums.length;k++){
if(tmp1[k]==nums[m]){
res[0]=k;
break;
}
}
//找到nums[n]在tmp1數組中的下標
for(int i=0;i<nums.length;i++){
if(tmp1[i]==nums[n]&&i!=k)
res[1]=i;
}
return res;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/21369.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/21369.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/21369.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

李廉洋:6.3黃金原油下周一開盤行情價格漲跌趨勢分析及最新操作建議多空布局

黃金消息面分析&#xff1a;上周黃金市場的走勢受到了PCE通脹數據和美聯儲政策預期的顯著影響。盡管市場對黃金的長期看漲情緒依然存在&#xff0c;但短期內金價的波動性預計將持續。4月份的PCE通脹數據顯示價格壓力有所降溫&#xff0c;這一結果與分析師預期一致&#xff0c;但…

2024年6月2日 (周日) 葉子游戲新聞

中醫百科中藥: 中醫百科中藥是一款非常強大的中藥知識科普軟件&#xff0c;該應用提供500多味中草藥的文獻資料&#xff0c;強大的搜索功能可根據功效、特點和關鍵詞來快速查找中藥&#xff0c;而且每味中藥的圖片、功效、主治、炮制方法等百科知識&#xff0c;可以很好的幫助你…

Pycharm SSH遠程連接時出現報錯,測試 SFTP 連接,連接到 ‘connect.westb.seetacloud.com‘ 失敗

問題由來 很離譜&#xff01;今天本來打算租借AutoDL的顯卡完成一項深度學習的任務&#xff0c;很離譜的是同步文件夾的時候報了標題說的錯。 就很莫名奇妙&#xff0c;一天都在網上找解決辦法&#xff0c;結果都不對頭。 其他報錯 最后摸索著&#xff0c;在使用pycharm遠程登…

SpringBoot 定時任務+Quartz

1、分部解釋2、整體代碼 前言&#xff1a; 1、定時任務技術&#xff1a; JDK 的 Timer&#xff0c; 定義多個定時任務&#xff0c;其中某個任務出現異常&#xff0c;當時整個定時任務終止。Spring Task &#xff0c; 不支持 持久化與分布式部署&#xff0c;所有任務是單線程執行…

Prism 入門01,基礎

Prism 框架是支持多平臺的一種MVVM框架(Model-View-ViewModel) 除了具備一些基礎的屬性通知綁定,命令操作,消息聚合器等功能外。還具備一些強大的功能:例如,區域,導航,會話服務,模塊注入等特性。 一.如何在WPF 項目中使用Prism 框架 1.打開Visual Studio 2022,選擇創…

初探Arthasan安裝使用

最近在項目中用到 Arthas&#xff0c;即阿爾塞斯 是阿里開源的Java分析工具。 下載地址&#xff1a;Github 一、安裝運行 1&#xff09;window 系統 下載 jar 包&#xff0c;直接通過java命令運行 // 下載 jar包 curl -O https://arthas.aliyun.com/arthas-boot.jar // 啟動…

3個常用的Python性能分析工具及其使用方法

以下是幾個常用的性能分析工具及其使用方法和常用命令&#xff1a; 1. cProfile cProfile是Python標準庫中的性能分析工具&#xff0c;可以用來統計函數的運行時間和調用次數。 使用方法&#xff1a; 在命令行中使用以下命令&#xff1a; python -m cProfile my_script.py…

【排序】選擇排序(含優化版)

本章我們繼續講排序算法&#xff0c;這里我們將學習選擇排序&#xff0c;也是一個很普遍很常見的排序算法&#xff0c;邏輯和代碼都比較簡單&#xff0c;比較容易掌握&#xff0c;我們直接走起 選擇排序 基本思想&#xff1a;選擇排序&#xff08;SelectSort&#xff09;&…

Layui2.5.6樹形表格TreeTable使用

1、問題概述? Layui2.5.6的樹形表格-TreeTable終于用明白了,步驟詳細,提供源碼下載。 如果你使用的是Layui2.8+版本,那么點個贊,趕緊去官網看吧,官網更行了。 更新地址:樹表組件 treeTable - Layui 文檔 最近在項目中需要使用到樹形表格,用來顯示菜單的層級關系,當…

(delphi11最新學習資料) Object Pascal 學習筆記---第14章泛型第1節(泛型鍵值對)

14.1.1 內聯變量和泛型類型推斷 ? 在聲明泛型變量時&#xff0c;聲明可能相當長。在創建該類型的對象時&#xff0c;必須重復相同的聲明。除非您利用內聯變量聲明及其變量類型推斷的能力。因此&#xff0c;上面最后一個代碼片段可以寫成&#xff1a; beginvar Kvi : TKeyVal…

Leetcode 第 398 場周賽題解

Leetcode 第 398 場周賽題解 Leetcode 第 398 場周賽題解題目1&#xff1a;3151. 特殊數組 I思路代碼復雜度分析 題目2&#xff1a;3152. 特殊數組 II思路代碼復雜度分析 題目3&#xff1a;3153. 所有數對中數位不同之和思路代碼復雜度分析 題目4&#xff1a;3154. 到達第 K 級…

辯證 邏輯學 | 洞察 事物矛盾及變化規律 在形式邏輯基礎上 學會辯證思維(40節課)

課程下載&#xff1a;辯證邏輯學洞察事物矛盾及變化規律在形式邏輯基礎上學會辯證思維&#xff08;40節課&#xff09;-課程網盤鏈接提取碼下載.txt資源-CSDN文庫 更多資源下載&#xff1a;關注我。 在形式邏輯的基礎上&#xff0c;學會 辯證思維 敏銳 洞察事物發展變化的規…

Linux命令篇(一):文件管理部分

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;歡迎各位來到我的博客&#xff0c;很高興能夠在這里和您見面&#xff01;希望您在這里不僅可以有所收獲&#xff0c;同時也能感受到一份輕松歡樂的氛圍&#xff0c;祝你生活愉快&#xff01; 文章目錄 1、cat命令常用參…

童趣盎然,米香四溢 —— 蒙自源六一兒童節特別獻禮

充滿歡聲笑語的六一兒童節馬上就要來了&#xff0c;在這個充滿童真和喜悅的時刻&#xff0c;蒙自源米線品牌以一顆童心&#xff0c;為所有大朋友和小朋友準備了一份特別的禮物。 從5月25日開始&#xff0c;蒙自源誠摯邀請您和孩子們一同前往蒙自源旗下各大門店&#xff0c;品嘗…

【MySQL數據庫】MySQL 高可用搭建方案——MHA實戰

MHA&#xff08;Master High Availability&#xff09; MHA實戰 MHA&#xff08;Master High Availability&#xff09; 一、MHA簡介二、MHA搭建準備要求&#xff1a;mha集群搭建&#xff0c;4臺服務器&#xff0c;1主2從&#xff0c;1臺mha2.1實驗思路2.2實驗準備 三、搭建MyS…

每日一題31:數據統計之即時配送食物

一、每日一題 配送表: Delivery -------------------------------------- | Column Name | Type | -------------------------------------- | delivery_id | int | | customer_id | int | | order_date …

HTML5常用標簽表格

04-08、表格標簽table 概述 表格&#xff1a;是一種行和列組合而成的單元格。一般應用于后臺網頁設計管理數據使用。 表格的架構部分&#xff1a; tabletable head 表格頭 theadtable body - 表格體 tbodytable foot -表格的頁腳 tfoot 表格的基本組成部分&#xff1a; t…

Bluetooth Profiles,藍牙配置文件對應設備

下面的常量是藍牙各種配置文件的標識符。 每個常量代表一個特定的藍牙配置文件&#xff0c;這些配置文件定義了藍牙設備之間通信的特定方式。以下是每個常量的解釋&#xff1a; HEADSET (1): 代表耳機和免提配置文件&#xff0c;通常用于藍牙耳機或車載免提系統。A2DP (2): 代…

opencv-python(三)

馬賽克 face img[162:428,297:527] # 人臉坐標區域face face[::10,::10] # 每10個中取出一個像素&#xff0c;馬賽克face np.repeat(face, 10, axis0) # 行方向重復10次face np.repeat(face, 10, axis1) # 列方向重復10次img[162:428,297:527] face[:266,:230] # 填充&a…

計算機科學與技術和軟件工程專業有什么區別?應該怎么選?

計算機科學與技術和軟件工程都是就業前景較好的計算機類專業&#xff0c;二者密切相關但側重點不同&#xff0c;同學們應該如何選擇呢&#xff1f; 一、學習內容 1.學科定位 ● 計算機科學與技術 側重于計算機科學的理論研究和基礎技術&#xff0c;包括算法、數據結構、人工…