go語(yǔ)言題解LeetCode88合并兩個(gè)有序數(shù)組示例
題目描述
原題鏈接 :
給你兩個(gè)按 非遞減順序 排列的整數(shù)數(shù)組 nums1
和 nums2
,另有兩個(gè)整數(shù) m
和 n
,分別表示 nums1
和 nums2
中的元素?cái)?shù)目。
請(qǐng)你 合并 nums2
到 nums1
中,使合并后的數(shù)組同樣按 非遞減順序 排列。
注意:最終,合并后數(shù)組不應(yīng)由函數(shù)返回,而是存儲(chǔ)在數(shù)組 nums1
中。為了應(yīng)對(duì)這種情況,nums1
的初始長(zhǎng)度為 m + n
,其中前 m
個(gè)元素表示應(yīng)合并的元素,后 n
個(gè)元素為 0 ,應(yīng)忽略。nums2
的長(zhǎng)度為 n
。
示例 1:
輸入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3 輸出:[1,2,2,3,5,6] 解釋:需要合并 [1,2,3] 和 [2,5,6] 。 合并結(jié)果是 [1,2,2,3,5,6] ,其中斜體加粗標(biāo)注的為 nums1 中的元素。
示例 2:
輸入:nums1 = [1], m = 1, nums2 = [], n = 0 輸出:[1] 解釋:需要合并 [1] 和 [] 。 合并結(jié)果是 [1] 。
示例 3:
輸入:nums1 = [0], m = 0, nums2 = [1], n = 1 輸出:[1] 解釋:需要合并的數(shù)組是 [] 和 [1] 。 合并結(jié)果是 [1] 。 注意,因?yàn)?m = 0 ,所以 nums1 中沒(méi)有元素。nums1 中僅存的 0 僅僅是為了確保合并結(jié)果可以順利存放到 nums1 中。
提示:
nums1.length == m + n
nums2.length == n
0 <= m, n <= 200
1 <= m + n <= 200
-10^9 <= nums1[i], nums2[j] <= 10^9 進(jìn)階:你可以設(shè)計(jì)實(shí)現(xiàn)一個(gè)時(shí)間復(fù)雜度為 O(m + n) 的算法解決此問(wèn)題嗎?
思路分析
代碼超簡(jiǎn)單,從后往前看,用兩個(gè)指針掃描兩個(gè)數(shù)組,邊比較邊存數(shù),第三個(gè)指針指向nums1的末尾存數(shù),存儲(chǔ)挪過(guò)來(lái)的大數(shù)。掃描指針移動(dòng)條件是,該數(shù)組有小的數(shù)。
退出條件是:nums2的索引到最左邊,說(shuō)明數(shù)的比較和移動(dòng)全部完成。需要注意的是i可能會(huì)因?yàn)閚ums2中的數(shù)都比較小,一直導(dǎo)致左超限。
AC 代碼
class Solution { public void merge(int[] nums1, int m, int[] nums2, int n) { // 開了三個(gè)指針,從后往前遍歷,二個(gè)掃描,一個(gè)存數(shù) int i = m-1, j = n-1, k = m+n-1; // 循環(huán)條件:當(dāng)nums2檢查完,整個(gè)工作也完成了。 while (j >= 0) { // 注意執(zhí)行順序,先判斷i >= 0,再判斷數(shù)大小,否則會(huì)報(bào)索引超限錯(cuò)誤。 if (i >= 0 && nums1[i] > nums2[j]) { nums1[k] = nums1[i]; i--; } // 執(zhí)行else條件:不滿足if中的任意一個(gè)條件。 else { nums1[k] = nums2[j]; j--; } k--; } } }
以上就是go語(yǔ)言題解LeetCode88合并兩個(gè)有序數(shù)組示例的詳細(xì)內(nèi)容,更多關(guān)于go 合并兩個(gè)有序數(shù)組的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Spring啟動(dòng)指定時(shí)區(qū)的兩種方法
最近項(xiàng)目啟動(dòng),時(shí)間要修改成東七區(qū)時(shí)間,本文主要介紹了Spring啟動(dòng)指定時(shí)區(qū)的兩種方法,具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11JavaEE組件commons-fileupload實(shí)現(xiàn)文件上傳、下載
這篇文章主要介紹了JavaEE組件commons-fileupload實(shí)現(xiàn)文件上傳、下載,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10如何使用Maven管理項(xiàng)目?Maven管理項(xiàng)目實(shí)例
下面小編就為大家?guī)?lái)一篇如何使用Maven管理項(xiàng)目?Maven管理項(xiàng)目實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06Java?guava框架LoadingCache及CacheBuilder本地小容量緩存框架總結(jié)
Guava?Cache本地緩存框架主要是一種將本地?cái)?shù)據(jù)緩存到內(nèi)存中,但數(shù)據(jù)量并不能太大,否則將會(huì)占用過(guò)多的內(nèi)存,本文給大家介紹Java?guava框架?LoadingCache及CacheBuilder?本地小容量緩存框架總結(jié),感興趣的朋友一起看看吧2023-12-12使用gRPC微服務(wù)的內(nèi)部通信優(yōu)化
這篇文章主要為大家介紹了微服務(wù)優(yōu)化之使用gRPC做微服務(wù)的內(nèi)部通信,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03Spring Boot支持Crontab任務(wù)改造的方法
這篇文章主要介紹了Spring Boot支持Crontab任務(wù)改造的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01在SpringBoot中如何利用Redis實(shí)現(xiàn)互斥鎖
當(dāng)我們利用Redis存儲(chǔ)熱點(diǎn)數(shù)據(jù)時(shí),突然就過(guò)期失效或者被刪除了,導(dǎo)致大量請(qǐng)求同時(shí)訪問(wèn)數(shù)據(jù)庫(kù),增加了數(shù)據(jù)庫(kù)的負(fù)載,為減輕數(shù)據(jù)庫(kù)的負(fù)載我們利用互斥鎖,本文重點(diǎn)介紹在SpringBoot中如何利用Redis實(shí)現(xiàn)互斥鎖,感興趣的朋友一起看看吧2023-09-09