第4周專案3單鏈表應用

2021-07-23 01:31:46 字數 1884 閱讀 8847

1.設計乙個演算法,將乙個帶頭結點的資料域依次為a1,a2,…,an(n≥3)的單鏈表的所有結點逆置,即第乙個結

點的資料域變為an,…,最後乙個結點的資料域為a1。實現這個演算法,並完成測試。

2.已知l1和l2分別指向兩個單鏈表的頭結點,且已知其長度分別為m、n,請設計演算法將l2連線到l1的後面。實現這個演算法,完成測試,並分析這個演算法的複雜度。

**:

#include "linklist.h"

void reverse(linklist *&l)

}int main()

; createlistr(l,a,8);

printf("l:");

displist(l);

reverse(l);

printf("逆置後l:");

displist(l);

destroylist(l);

return 0;

}

執行結果:

**:

#include "linklist.h"

void link(linklist *&l1, linklist *&l2)

int main()

; elemtype b= ;

initlist(a);

for(i=3; i>=0; i--)

listinsert(a, 1, a[i]);

initlist(b);

for(i=5; i>=0; i--)

listinsert(b, 1, b[i]);

link(a, b);

printf("a:");

displist(a);

destroylist(a);

return 0;

}

執行結果:

**

#include "linklist.h"

bool increase(linklist *l)

}return true;

}int main()

; elemtype b= ;

initlist(a);

for(i=3; i>=0; i--)

listinsert(a, 1, a[i]);

initlist(b);

for(i=5; i>=0; i--)

listinsert(b, 1, b[i]);

printf("a: %c\n", increase(a)?'y':'n');

printf("b: %c\n", increase(b)?'y':'n');

destroylist(a);

destroylist(b);

return 0;

}

執行結果:

知識點總結:

考察了單鏈表判斷遞增,逆置,鏈結應用

學習心得:

雖然演算法比較簡單,但是發揮了很大的作用。

第4周 專案3 單鏈表應用

all right reserved.檔名稱 20170928.cpp 完成日期 2017年9月28日 版本號 v1.1 輸入描述 建立單鏈表 程式輸出 輸出單鏈表 linklist.h ifndef linklist h included define linklist h included ty...

第4周 專案3 單鏈表應用 3

檔名稱 aaa.cpp 作 者 董子賓 完成日期 2015年 10月 5日 版 本 號 v1.0 問題描述 設計乙個演算法,判斷單鏈表l是否是遞增的。實現這個演算法,並完成測試。輸入描述 無 程式輸出 測試結果 問題及 include include include linklist.h bool ...

第4周專案3單鏈表應用3

檔名稱 text.cpp 完成日期 2015年10月9日 問題描述 1 設計乙個演算法,將乙個帶頭結點的資料域依次為a1,a2,an n 3 的單鏈表的所有結點逆置,即第乙個結點的資料域變為an,最後乙個結點的資料域為a1。實現這個演算法,並完成測試。2 已知l1和l2分別指向兩個單鏈表的頭結點,且...