久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

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

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

創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供石峰網(wǎng)站建設(shè)、石峰做網(wǎng)站、石峰網(wǎng)站設(shè)計(jì)、石峰網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、石峰企業(yè)網(wǎng)站模板建站服務(wù),10多年石峰做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

題目要求:

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

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

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

鏈表結(jié)點(diǎn)定義:

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++程序設(shè)計(jì)有所幫助。

本文題目:C++實(shí)現(xiàn)單鏈表按k值重新排序的方法
URL地址:http://sd-ha.com/article0/pepeio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)、企業(yè)網(wǎng)站制作、域名注冊、做網(wǎng)站、網(wǎng)站策劃、網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)