欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)LeetCode(88.混合插入有序數(shù)組)

 更新時間:2021年07月13日 14:24:46   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode(88.混合插入有序數(shù)組),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下

[LeetCode] 88. Merge Sorted Array 混合插入有序數(shù)組

Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array.

Note:

  • The number of elements initialized in nums1and nums2 are m and n respectively.
  • You may assume that nums1 has enough space (size that is greater or equal to m + n) to hold additional elements from nums2.

Example:

Input:
nums1 = [1,2,3,0,0,0], m = 3
nums2 = [2,5,6],       n = 3

Output: [1,2,2,3,5,6]

混合插入有序數(shù)組,由于兩個數(shù)組都是有序的,所有只要按順序比較大小即可。題目中說了 nums1 數(shù)組有足夠大的空間,說明不用 resize 數(shù)組,又給了m和n,那就知道了混合之后的數(shù)組的大小,這樣就從 nums1 和 nums2 數(shù)組的末尾開始一個一個比較,把較大的數(shù),按順序從后往前加入混合之后的數(shù)組末尾。需要三個變量 i,j,k,分別指向 nums1,nums2,和混合數(shù)組的末尾。進行 while 循環(huán),如果i和j都大于0,再看如果 nums1[i] > nums2[j],說明要先把 nums1[i] 加入混合數(shù)組的末尾,加入后k和i都要自減1;反之就把 nums2[j] 加入混合數(shù)組的末尾,加入后k和j都要自減1。循環(huán)結束后,有可能i或者j還大于等于0,若j大于0,那么還需要繼續(xù)循環(huán),將 nums2 中的數(shù)字繼續(xù)拷入 nums1。若是i大于等于0,那么就不用管,因為混合數(shù)組本身就放在 nums1 中,參見代碼如下:

解法一: 

class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
        int i = m - 1, j = n - 1, k = m + n - 1;
        while (i >= 0 && j >= 0) {
            if (nums1[i] > nums2[j]) nums1[k--] = nums1[i--];
            else nums1[k--] = nums2[j--];
        }
        while (j >= 0) nums1[k--] = nums2[j--];
    }
};

我們還可以寫的更簡潔一些,將兩個 while 循環(huán)融合到一起,只要加上 i>=0 且 nums1[i] > nums2[j] 的判斷條件,就可以從 nums1 中取數(shù),否則就一直從 nums2 中取數(shù),參見代碼如下:

解法二:

class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
        int i = m - 1, j = n - 1, k = m + n - 1;
        while (j >= 0) {
            nums1[k--] = (i >= 0 && nums1[i] > nums2[j]) ? nums1[i--] : nums2[j--];
        }
    }
};

到此這篇關于C++實現(xiàn)LeetCode(88.混合插入有序數(shù)組)的文章就介紹到這了,更多相關C++實現(xiàn)混合插入有序數(shù)組內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C語言中數(shù)組排序淺析

    C語言中數(shù)組排序淺析

    這篇文章主要為大家介紹了C語言算法練習中數(shù)組元素排序的四種類型,文中的示例代碼講解詳細,對我們學習C語言有一定幫助,需要的可以參考一下
    2022-12-12
  • C++布隆過濾器的使用示例

    C++布隆過濾器的使用示例

    寧可錯殺一千,也不放過一個,這是布隆過濾器的特點,本文主要介紹了C++布隆過濾器的使用示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-09-09
  • Qt實現(xiàn)UI界面純代碼示例

    Qt實現(xiàn)UI界面純代碼示例

    這篇文章主要給大家介紹了關于Qt實現(xiàn)UI界面的相關資料,使用Qt純代碼,實現(xiàn)了基本的界面,對大家學習或者使用Qt具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-01-01
  • C++實現(xiàn)LeetCode(200.島嶼的數(shù)量)

    C++實現(xiàn)LeetCode(200.島嶼的數(shù)量)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(200.島嶼的數(shù)量),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C C++ 題解LeetCode2360圖中的最長環(huán)示例

    C C++ 題解LeetCode2360圖中的最長環(huán)示例

    這篇文章主要為大家介紹了C C++ 題解LeetCode2360圖中的最長環(huán)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • VSCode (Visual Studio Code) V1.43.0下載并設置成中文語言的方法

    VSCode (Visual Studio Code) V1.43.0下載并設置成中文語言的方法

    Visual Studio Code是一款免費開源的現(xiàn)代化輕量級代碼編輯器,支持語法高亮、智能代碼補全、自定義熱鍵、括號匹配、代碼片段、代碼對比 Diff、GIT 等特性,這篇文章主要介紹了VSCode (Visual Studio Code) V1.43.0下載并設置成中文語言,需要的朋友可以參考下
    2020-03-03
  • 詳解C++中的萬能頭文件

    詳解C++中的萬能頭文件

    C++萬能頭文件它是一個包含了每一個標準庫的頭文件,接下來通過本文給大家介紹C++中的萬能頭文件及優(yōu)缺點,需要的朋友可以參考下
    2023-02-02
  • C++學習小結之二進制轉換

    C++學習小結之二進制轉換

    這篇文章主要介紹了C++學習小結之二進制轉換的相關資料,需要的朋友可以參考下
    2015-07-07
  • C語言強制類型轉換規(guī)則實例詳解

    C語言強制類型轉換規(guī)則實例詳解

    強制類型轉換是把變量從一種類型轉換為另一種數(shù)據(jù)類型,下面這篇文章主要給大家介紹了關于C語言強制類型轉換的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-06-06
  • C++實現(xiàn)簡單通訊錄管理系統(tǒng)

    C++實現(xiàn)簡單通訊錄管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)簡單通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02

最新評論