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)文章
IDEA(2022.2)搭建Servlet基本框架超詳細(xì)步驟
這篇文章主要給大家介紹了關(guān)于IDEA(2022.2)搭建Servlet基本框架超詳細(xì)步驟,Servlet容器負(fù)責(zé)Servlet和客戶的通信以及調(diào)用Servlet的方法,Servlet和客戶的通信采用"請(qǐng)求/響應(yīng)"的模式,需要的朋友可以參考下2023-10-10
基于Java實(shí)現(xiàn)五子棋小游戲(附源碼)
這篇文章主要為大家介紹了如何通過(guò)Java實(shí)現(xiàn)簡(jiǎn)單的五子棋游戲,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Java游戲開發(fā)有一定幫助,需要的可以參考一下2022-11-11
idea編譯時(shí)不提示任何錯(cuò)誤信息的問(wèn)題及解決
這篇文章主要介紹了idea編譯時(shí)不提示任何錯(cuò)誤信息的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
Spring Boot 開發(fā)環(huán)境熱部署詳細(xì)教程
這篇文章主要介紹了Spring Boot 開發(fā)環(huán)境熱部署,本文給大家介紹了Spring Boot 開發(fā)環(huán)境熱部署的原理及快速配置方法,通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
解析Java中的Timer和TimerTask在Android中的用法和實(shí)例
本篇文章主要介紹了解析Java中的Timer和TimerTask在Android中的用法,主要介紹了Timer和TimerTask的用法,有需要的可以了解一下。2016-11-11
SpringBoot Mybatis動(dòng)態(tài)數(shù)據(jù)源切換方案實(shí)現(xiàn)過(guò)程
這篇文章主要介紹了SpringBoot+Mybatis實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)源切換方案過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04

