4001.基于雙向鏈表的雙向冒泡排序法

基于雙向鏈表的雙向冒泡排序法

發布時間: 2018年11月26日 10:09?? 時間限制: 1000ms?? 內存限制: 128M

習題集源碼中出現了?temp->next->prior = p;?本人推斷這里缺少預先的對temp->next==NULL這種情況的判定,所以需加入一個判斷語句解決。

此為非循環的雙向鏈表,末尾空指針沒有前驅,與循環雙向鏈表有所不同。

描述

有n個記錄存儲在帶頭結點的雙向鏈表中,利用雙向冒泡排序法對其按上升序進行排序,請寫出這種排序的算法。(注:雙向冒泡排序即相鄰兩趟排序向相反方向冒泡)。

輸入

多組數據,每組數據兩行。第一行為序列的長度n,第二行為序列的n個元素(元素之間用空格分隔,元素都為正整數)。當n等于0時,輸入結束。

輸出

每組數據輸出一行,為從小到大排序后的序列。每兩個元素之間用空格隔開。

樣例輸入1
5
4 5 3 2 9
6
1 3 5 7 9 2
0
樣例輸出1
2 3 4 5 9
1 2 3 5 7 9
 1 //雙向冒泡,最大沉底,最小冒出
 2 #include<iostream>
 3 using namespace std;
 4 typedef struct node
 5 {
 6     int data;
 7     struct node *prior, *next;
 8 }node, *LinkList;
 9 void TwoWayBubbleSort(LinkList &L)
10 //對存儲在帶頭結點的雙向鏈表L中的元素進行雙向起泡排序。
11 {
12     int exchange = 1;//設標記
13     LinkList head = L;//雙向鏈表頭,算法過程中是向下起泡的開始結點
14     LinkList tail = NULL;//雙向鏈表尾,算法過程中是向上起泡的開始結點
15     while(exchange)
16     {
17         LinkList p = head->next;//p是工作指針,指向當前結點
18         exchange = 0;//假定本趟無交換
19         while (p->next != tail)//向下(右)起泡,一趟有一最大元素沉底
20         {
21             if (p->data > p->next->data)//交換兩結點指針,涉及6條鏈
22             {
23                 LinkList temp = p->next; exchange = 1;//有交換
24                 p->next = temp->next; 
25                 if(temp->next)temp->next->prior = p;//先將結點從鏈表上摘下
26                 //attention!存在temp->next=NULL的可能,NULL->prior無法訪問
27                 temp->next = p; p->prior->next = temp;//將temp插到p結點前
28                 temp->prior = p->prior; p->prior = temp;
29                 //p = p->next;
30             }
31             else p = p->next;//無交換,指針后移
32         }
33         tail = p;//準備向上起泡
34         p = tail->prior;
35         while (exchange&&p->prior != head)//向上(左)起泡,一趟有一最小元素冒出
36         {
37 
38             if (p->data < p->prior->data)//交換兩結點指針,涉及6條鏈
39             {
40                 LinkList temp = p->prior; exchange = 1;//有交換
41                 p->prior = temp->prior; temp->prior->next = p;
42                 //先將temp結點從鏈表上摘下
43                 temp->prior = p; p->next->prior = temp;
44                 //將temp插到p結點后(右)
45                 temp->next = p->next; p->next = temp;
46             }
47             else p = p->prior;//無交換,指針前移
48         }
49             head = p;//準備向下起泡
50     }
51 }
52 void Create(LinkList &L, int n)
53 {
54     LinkList p, rear;
55     L = new node;
56     L->next = NULL;
57     L->prior = NULL;
58     rear = L;
59     while (n--)
60     {
61         p = new node;
62         cin>>p->data;
63         p->next = rear->next;
64         rear->next = p;
65         p->prior = rear;
66         rear = p;
67     }
68 }
69 int main()
70 {
71     int n;
72     while (true)
73     {
74         cin >> n;
75         if (!n)break;
76         else 
77         {
78             LinkList L;
79             Create(L, n);
80             TwoWayBubbleSort(L);
81             LinkList p = L->next;
82             while (p->next)
83             {
84                 cout << p->data << " ";
85                 p = p->next;
86             }
87             cout << p->data << endl;
88         }
89         
90     }
91     return 0;
92 }

轉載于:https://www.cnblogs.com/wind-chaser/p/10049548.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450113.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450113.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450113.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

頁面向上滾動

#頁面或者div向上無縫滾動 1.css: body {margin: 0;padding: 0;overflow: hidden;}.container {position: relative;top: 0;}.container div {width: 500px;height: 500px;border: 1px solid chartreuse;font-size: 100px;line-height: 500px;font-weight: bold;color: black;t…

叨逼叨

此處記錄點零散的小idea&#xff0c;為了避免把csdn當微博&#xff0c;開一篇&#xff0c;都記在這里吧。 感覺服務注冊機制&#xff0c;貌似也是一種依賴注入。&#xff08;雖然我還沒完全搞懂依賴注入&#xff09;&#xff0c;理由呢&#xff1a;你需要一個模塊的功能&#x…

Linux:echo命令詳解

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 echo命令 用于字符串的輸出 格式 echo string使用echo實現更復雜的輸出格式控制 1.顯示普通字符串: echo "It is a test"這里…

看年輕人如何賺第一桶金

上世紀90年代&#xff0c;成為百萬富翁&#xff0c;對很多人只是個夢想。不過如今&#xff0c;隨著經濟飛速發展&#xff0c;擁有百萬資產已經不再是神話&#xff0c;放眼望去&#xff0c;我們身邊的百萬富翁比比皆是&#xff0c;甚至很多初入社會、白手起家的年輕人&#xff0…

跨越解決方案之nginx

這里是修真院前端小課堂&#xff0c;每篇分享文從 【背景介紹】【知識剖析】【常見問題】【解決方案】【編碼實戰】【擴展思考】【更多討論】【參考文獻】 八個方面深度解析前端知識/技能&#xff0c;本篇分享的是&#xff1a; 【跨越解決方案之nginx】 1.背景介紹 跨域&#x…

學習 shell腳本之前的基礎知識

見 : http://www.92csz.com/study/linux/12.htm【什么是shell】 簡單點理解&#xff0c;就是系統跟計算機硬件交互時使用的中間介質&#xff0c;它只是系統的一個工具。實際上&#xff0c;在shell和計算機硬件之間還有一層東西那就是系統內核了。打個比方&#xff0c;如果把計算…

「分塊系列」數列分塊入門3 解題報告

數列分塊入門3 題意概括 區間加法&#xff0c;區間求前驅。 寫在前面 這題的方法與分塊2方法極其類似&#xff0c;建議自行解決。 正題 和上一題類似&#xff0c;但是二分不是用來計數的&#xff0c;而是用來求小于c的最大值的。然后對于不完整快&#xff0c;將小于c的值求最大…

創業者自述:我的第一桶金是如何來的

記者采訪王宏筠的當天&#xff0c;北京氣溫已達到30℃&#xff0c;王宏筠從他的鐵灰色奧迪A6車上下來&#xff0c;一身挺括的西裝&#xff0c;打著領帶&#xff0c;肩上背著一個超大的牛皮包。后來他對記者說&#xff0c;穿西服是因為多年在外企養成的習慣&#xff0c;一年中至…

Git cherry-pick后再merge出現一個“奇怪”的現象

背景描述&#xff1a;有的時候基于一個master branch拉出一個獨立feature分支做開發時&#xff0c;兩條分支都在并行開發&#xff0c;如果master分支增加了某些功能&#xff0c;解決了某些關鍵bug&#xff0c;而獨立feature分支不需要所有的增加的commit&#xff0c;只需要某一…

inux系統中如何進入退出vim編輯器

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 VIM編輯器&#xff0c;可以新建文件也可以修改文件&#xff0c;命令為&#xff1a;vim AAA 。AAA就是文件名。 如果這個文件&#xff…

C++ 智能指針六

/* 智能指針unique_ptr */#include <iostream> #include <string> #include <memory> #include <vector>/*unique_ptr 獨占所指向的對象, 同一時刻只能有一個 unique_ptr 指向給定對象(通過禁止拷貝語義, 只有移動語義來實現), 定義于 memory (非memo…

如何掘到第一桶金

第一種類型&#xff1a;才智高遠型 典型代表&#xff1a;《福布斯》中國富豪榜排名第一位、個人資產總計達到83億元的中國希望集團劉氏兄弟。 與一般的創業者不同&#xff0c;劉氏四兄弟劉永言、劉永行、劉永美、劉永好一開始就悟透了“舍得”二字。他們本來都在國家企事業單…

Sublime Text3中文環境設置

Sublime Text3中文環境設置 1、首先打開安裝好的的Sublime軟件,選擇Preferences下面的Package Contorol選項出現彈窗方框 2、在彈窗輸入install package,選擇對應&#xff08;默認第一個&#xff0c;如圖這個&#xff09;命令點擊進入;安裝的時候&#xff0c;左下角會有進度條顯…

C/C++圖形化編程(2)

歸納編程學習的感悟&#xff0c; 記錄奮斗路上的點滴&#xff0c; 希望能幫到一樣刻苦的你&#xff01; 如有不足歡迎指正&#xff01; 共同學習交流&#xff01; &#x1f30e;歡迎各位→點贊 &#x1f44d; 收藏? 留言?&#x1f4dd; 站在巨人的肩上是為了超過巨人&#x…

Git clone之后你的硬盤上究竟發生了什么?

網上關于Git的使用有太多的博客&#xff0c;文章在講解了&#xff0c;大部分是在講解命令的用法&#xff0c;剩下一部分則在講解git的內部原理&#xff0c;看過講解基礎命令使用的文章后&#xff0c;正常的開發使用是沒有什么問題的了&#xff0c;而如果想更深入的了解git“高級…

Shell 語法

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1. 運行sh腳本的2種方法&#xff1a; ./AAA。sh 或者 sh AAA.sh 。&#xff08;其實后輟名不重要。是txt也是可以運行的。&#xff09;…

感知機模型的對偶形式[轉載]

轉自:https://blog.csdn.net/jaster_wisdom/article/details/78240949#commentBox 1.區分一下易混淆的兩個概念&#xff0c;梯度下降和隨機梯度下降&#xff1a; 梯度下降&#xff1a;一次將誤分類集合中所有誤分類點的梯度下降&#xff1b; 隨機梯度下降&#xff1a;隨機選取一…

Android Studio常用快捷鍵

注&#xff1a;本文大部分內容轉載自——碼個蛋微信公眾號里的“熟練這些&#xff0c;才會知道 Android studio 有多高效”由于是微信公眾號通過傳送門看的&#xff0c;沒有原文鏈接。 顯示方法的參數 當我們使用一個方法的時候&#xff0c;會在剛開始的時候顯示出所有的參數。…

中國城市政治地位,政治地位決定一切!!!

第一政治等級&#xff1a;省級城市&#xff08;包括直轄市、特別行政區&#xff09;6個 北京市、上海市、天津市、重慶市、香港特別行政區、澳門特別行政區 第二政治等級&#xff1a;副省級城市&#xff08;含五個計劃單列市&#xff09; 15個 沈陽市、大連市&…

Shell 字符串截取

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 Linux 的字符串截取很有用。有八種方法。 假設有變量 varhttp://www.aaa.com/123.htm 1. # 號截取&#xff0c;刪除左邊字符&#xff0c;…