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分別指向兩個單鏈表的頭結點,且...