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

C++實(shí)現(xiàn)合并兩個(gè)排序的鏈表

 更新時(shí)間:2019年03月03日 14:40:21   作者:francis_xd  
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)合并兩個(gè)排序的鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C++合并兩個(gè)排序的鏈表,供大家參考,具體內(nèi)容如下

問題描述

輸入兩個(gè)單調(diào)遞增的鏈表,輸出兩個(gè)鏈表合成后的鏈表,當(dāng)然我們需要合成后的鏈表滿足單調(diào)不減規(guī)則。

struct ListNode {
 int val;
 struct ListNode *next;
 ListNode(int x) :
 val(x), next(NULL) {
 }
};

方法一

class Solution {
public:
 ListNode* Merge(ListNode* pHead1, ListNode* pHead2)
 {
  ListNode* newList = NULL; //新鏈表頭
  ListNode* newListRear = NULL; //新鏈表尾
  // 先處理某個(gè)鏈表為空的情形
  if (pHead1 == NULL){
   return pHead2;
  }
  if (pHead2 == NULL){
   return pHead1;
  }
  // 把數(shù)值小的結(jié)點(diǎn)放入新鏈表,生成頭節(jié)點(diǎn)
  if (pHead1->val <= pHead2->val){
   newList = pHead1;
   newListRear = pHead1;
   pHead1 = pHead1->next;
  }else{
   newList = pHead2 ;
   newListRear = pHead2;
   pHead2 = pHead2->next;
  }
  // 兩表均不空的情形下,遍歷 
  while (pHead1 != NULL && pHead2 != NULL) {
   if (pHead1->val <= pHead2->val) {
    newListRear->next =pHead1;
    newListRear = pHead1;
    pHead1 = pHead1->next;
   }else{
    newListRear->next =pHead2;
    newListRear = pHead2;
    pHead2 = pHead2->next;
   }
  }
  //某一表為空時(shí),把另一表接入新表表尾 
  if (pHead1 == NULL) {
   newListRear->next = pHead2;
  }
  if (pHead2 == NULL) {
   newListRear->next = pHead1;
  }
  
  return newList;
 }
};

方法二(遞歸思想)

class Solution {
public:
 ListNode* Merge(ListNode* pHead1, ListNode* pHead2)
 {
  if (pHead1 == NULL){
   return pHead2;
  }
  if (pHead2 == NULL){
   return pHead1;
  }
  
  if (pHead1->val <= pHead2->val){ // pHead1為合并后的頭節(jié)點(diǎn)
   pHead1->next = Merge(pHead1->next, pHead2);
   return pHead1;
  }else{ // pHead2 為合并后的頭節(jié)點(diǎn)
   pHead2->next = Merge(pHead1, pHead2->next);
   return pHead2;
  }
 }
};

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 基于C語言實(shí)現(xiàn)掃雷游戲

    基于C語言實(shí)現(xiàn)掃雷游戲

    這篇文章主要為大家詳細(xì)介紹了基于C語言實(shí)現(xiàn)掃雷游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • VS2019上配置CUDA的環(huán)境步驟

    VS2019上配置CUDA的環(huán)境步驟

    本文主要介紹了VS2019上配置CUDA的環(huán)境步驟,文中通過圖文示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 從匯編看c++中多態(tài)的應(yīng)用

    從匯編看c++中多態(tài)的應(yīng)用

    本篇文章是對(duì)c++中多態(tài)的應(yīng)用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言預(yù)處理詳解

    C語言預(yù)處理詳解

    這篇文章主要給大家介紹了關(guān)于C語言之預(yù)處理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • VS2017開發(fā)C語言出現(xiàn)“no_init_all“的解決辦法

    VS2017開發(fā)C語言出現(xiàn)“no_init_all“的解決辦法

    這篇文章介紹了VS2017開發(fā)C語言出現(xiàn)“no_init_all“的解決辦法,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • 基于c++11的event-driven library的理解

    基于c++11的event-driven library的理解

    這篇文章主要介紹了基于c++11的event-driven library的理解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • C++多線程編程和同步機(jī)制實(shí)例演示

    C++多線程編程和同步機(jī)制實(shí)例演示

    C++中的多線程編程和同步機(jī)制使得程序員可以利用計(jì)算機(jī)的多核心來提高程序的運(yùn)行效率和性能,本文將介紹多線程編程和同步機(jī)制的基本概念和使用方法
    2023-09-09
  • C語言超詳細(xì)講解順序表的各種操作

    C語言超詳細(xì)講解順序表的各種操作

    大家好,今天給大家?guī)淼氖琼樞虮?,我覺得順序表還是有比較難理解的地方的,于是我就把這一塊的內(nèi)容全部整理到了一起,希望能夠給剛剛進(jìn)行學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的人帶來一些幫助,或者是已經(jīng)學(xué)過這塊的朋友們帶來更深的理解,我們現(xiàn)在就開始吧
    2022-05-05
  • C語言 表、棧和隊(duì)列詳解及實(shí)例代碼

    C語言 表、棧和隊(duì)列詳解及實(shí)例代碼

    這篇文章主要介紹了C語言 表、棧和隊(duì)列詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • Linux網(wǎng)絡(luò)編程之UDP Socket程序示例

    Linux網(wǎng)絡(luò)編程之UDP Socket程序示例

    這篇文章主要介紹了Linux網(wǎng)絡(luò)編程之UDP Socket程序示例,有助于讀者在實(shí)踐中掌握UDP協(xié)議的原理及應(yīng)用方法,需要的朋友可以參考下
    2014-08-08

最新評(píng)論