雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

C語言

當前位置:主頁 > 軟件編程 > C語言 >

C++實現(xiàn)單鏈表按k值重新排序的方法

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊:

本文實例講述了C++實現(xiàn)單鏈表按k值重新排序的方法。分享給大家供大家參考,具體如下:

題目要求:

給定一鏈表頭節(jié)點,節(jié)點值類型是整型。
現(xiàn)給一整數(shù)k,根據(jù)k將鏈表排序為小于k,等于k,大于k的一個鏈表。
對某部分內的節(jié)點順序不做要求。

算法思路分析及代碼(C)

思路:將鏈表分為小于k、等于k、大于k的三個鏈表,然后再合并。

鏈表結點定義:

typedef struct Node
{
  int data;
  struct Node* next;
}node, *pNode;

算法代碼:

pNode sortLinkedList(pNode head, int k)
{
  pNode sHead = NULL;//小頭
  pNode sTail = NULL;//小尾
  pNode eHead = NULL;//等頭
  pNode eTail = NULL;//等尾
  pNode bHead = NULL;//大頭
  pNode bTail = NULL;//大尾
  pNode temp = NULL;
  //拆分鏈表
  while (head != NULL)
  {
    temp = head->next;
    head->next = NULL;
    if (head->data < k)
    {
      if (!sHead){
        sHead = head;
        sTail = head;
      }
      else{
        sTail->next = head;
        sTail = head;
      }
    }
    else if (head->data == k)
    {
      if (!eHead){
        eHead = head;
        eTail = head;
      }
      else{
        eTail->next = head;
        eTail = head;
      }
    }
    else
    {
      if (!bHead){
        bHead = head;
        bTail = head;
      }
      else{
        bTail->next = head;
        bTail = head;
      }
    }
    head = temp;
  }
  //合并鏈表
  if (sTail)
  {
    sTail->next = eHead;
    eTail = (eTail == NULL ? sTail : eTail);
  }
  if (eTail)
  {
    eTail->next = bHead;
  }
  return sHead != NULL ? sHead : (eHead != NULL ? eHead : bHead);
}

希望本文所述對大家C++程序設計有所幫助。

上一篇:淺談c++中的while(cin)問題

欄    目:C語言

下一篇:淺談c++的編譯和運行

本文標題:C++實現(xiàn)單鏈表按k值重新排序的方法

本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1610.html

網(wǎng)頁制作CMS教程網(wǎng)絡編程軟件編程腳本語言數(shù)據(jù)庫服務器

如果侵犯了您的權利,請與我們聯(lián)系,我們將在24小時內進行處理、任何非本站因素導致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權所有