線性表演算法設計題1
1.設線性表L=(a1,a2,a3,…,a[n-2],a[n-1],an)採用帶頭結點的單連結串列儲存,連結串列中結點定義如下:
typedef struct node{
int data;
struct node* next;
}NODE;
請設計一個空間複雜度為O(1)且時間上儘可能高效的演算法,重新排列L中的個結點得到線性表L’=(a1,an,a2,a[n-1],a3,a[n-2],…)。
要求:
(1)給出演算法的基本設計思想。
(2)根據設計思想,採用c或c++語言描述演算法,關鍵之處給出註釋。
(3)說明你所設計的演算法的時間複雜度。【2019年全國試題41(13)分】
答:(1)將原有連結串列從中間分為兩部分,分別是(a1,a2,a3,…a[n/2])和(a[n/2+1],a[n/2+2],…,a[n])。將後一部分連結串列逆置,再將兩個連結串列合併。
(2)核心語句
int i=1;
p=head->next; //設head是指向帶頭結點的單連結串列的指標
while(i<n/2){ //n為元素個數(題目有提示)
p=p->next;//找到兩個連結串列的分界點,即中間結點
i++;
}
r=p->next; //r即為第二個連結串列的頭結點
p->next=null;//p結點是前一半的尾結點
q=null; //為逆置做準備,q指向逆置表的首元結點
while(r){//連結串列逆置
p=r->next;//暫存後繼
r->next=q;//就地逆置
q=r; //r(或q)指向連結串列新首元
r=p; //指向待逆置結點
}
p=head->next;//head是指向帶頭結點的單連結串列的指標,p指向連結串列的第一個元素
while(p->next&&q->next){
p->next=r; //暫存兩連結串列後繼
q->next=s;
p->next=q->next; //合併連結串列,將q結點插入到對應p結點的後面
p=r; //恢復指向待合併結點
q=s;
}
if(p->next==null) //*避免n為奇數,這步有些小問題,稍後修改*
p->next=q;
else
q->next=p;
(3)演算法的時間複雜度為O(n)。
總結
1.演算法涉及
(1)拆分連結串列
(2)逆置連結串列
(3)合併連結串列
逆置連結串列的幾種擴充:
1.無頭結點的單連結串列的逆置
2.帶附加頭結點的單連結串列的逆置
eg1:有一個無頭結點的單連結串列,結點有資料域data、指標域next,表頭指標為h,通過遍歷連結串列,將連結串列中所有的連結方向逆轉。要求逆轉後的連結串列的表頭指標h指向原連結串列的最後一個結點。演算法如下所示。【南京理工大學2005二、1(3分)】
void Inverse(&h){
if(h==null)
return ;
p=h->next;
pr=null;
while(p){
h->next=pr;
pr=h;
h=p;
p=p->next;
}
head->next=pr;
}
eg2:以下程式的功能就是實現帶附加頭結點的單連結串列資料結構逆序連結【西南交通大學2000一、9】
void reverse(pointer h){
/*h為附加頭結點*/
pointer p,q;
p=h->next;
h->next=null;
while(p!=null){
q=p;
p=p->next;
q->next=h->next;
h->next=q;
}
}
相關文章
- 線性表演算法實現演算法
- 燈光水舞秀表演的設計要點
- 程式設計與線性代數程式設計
- A - Frog 1(線性dp)
- 1-線性模型模型
- Chapter 1 線性表APT
- 演算法分析與設計 - 作業1演算法
- MATLAB版線性代數-線性方程組1Matlab
- SOLIDWORKS設計包線性靜態模擬Solid
- 線性迴歸演算法演算法
- 手擼機器學習演算法 - 非線性問題機器學習演算法
- ArgoDB 3.2新增智慧建表演算法,在建表時能夠自動設定Go演算法
- 線性表學習1
- 1維線性迴歸
- C#資料結構與演算法1-C# 線性表C#資料結構演算法
- 演算法與資料結構1800題 之線性表 (三)演算法資料結構
- [譯]在 Flutter 中如何設計線性佈局?Flutter
- 圖的鄰接表演算法---(附完整程式碼)演算法
- 演算法金 | 線性迴歸:不能忽視的五個問題演算法
- 簡明線性迴歸演算法演算法
- C語言程式設計題T1C語言程式設計
- Java併發程式設計-併發程式設計的Bug源頭:可見性、原子性和有序性問題Java程式設計
- CloudCompare 計演算法線Cloud演算法
- 演算法系列1 初識演算法 演算法複雜性模型 演算法複雜度的計算演算法模型複雜度
- 程式設計師進階之路之面試題與筆試題集錦(三)線上程式設計題程式設計師面試題筆試
- Python學習筆記-StatsModels 統計迴歸(1)線性迴歸Python筆記
- 線性表及其演算法(java實現)演算法Java
- 序列並查集的線性演算法並查集演算法
- 學堂線上,清華大學,線性代數(1),第十三講,習題10
- 前端中的簡單程式設計題-字串(1)前端程式設計字串
- 今日頭條程式設計題1 找"最大"點程式設計
- 機器學習演算法(一):1. numpy從零實現線性迴歸機器學習演算法
- 使用javascript一樣可以做線上演算法程式設計JavaScript演算法程式設計
- 演算法與資料結構1800題 之 陣列與線性表(三)演算法資料結構陣列
- Java併發程式設計-解決可見性與有序性問題Java程式設計
- Java併發程式設計Bug源頭:可見性、原子性和有序性問題Java程式設計
- 演算法題——冗餘連線演算法
- 面向大規模AI線上推理的可靠性設計AI