第三週 專案四 順序表應用 (2)

2021-08-08 13:52:16 字數 2712 閱讀 5854

/*

* 檔名稱:

* 作    者:張翠平

* 完成日期:2017 年 9 月 21 日

* 版 本 號:v1.0

** 問題描述:將順序表中所有奇數移到所有偶數的前面。

* 輸入描述:無

* 程式輸出:移動後的所有元素。

*/問題及**:

list.h

#ifndef list_h_included

#define list_h_included

#define maxsize 50

typedef int elemtype;

typedef struct

sqlist;

void createlist(sqlist *&l, elemtype a, int n);//用陣列建立線性表

void initlist(sqlist *&l);//初始化線性表initlist(l)

void destroylist(sqlist *&l);//銷毀線性表destroylist(l)

bool listempty(sqlist *l);//判定是否為空表listempty(l)

int listlength(sqlist *l);//求線性表的長度listlength(l)

void displist(sqlist *l);//輸出線性表displist(l)

bool getelem(sqlist *l,int i,elemtype &e);//求某個資料元素值getelem(l,i,e)

int locateelem(sqlist *l, elemtype e);//按元素值查詢locateelem(l,e)

bool listinsert(sqlist *&l,int i,elemtype e);//插入資料元素listinsert(l,i,e)

//int deletelist(sqlist *&l,int n);//刪除資料元素listdelete(l,n)#endif // list_h_included

void unionlist(sqlist *la, sqlist *lb, sqlist *&lc);

void move(sqlist *&l);//移動結束後,奇數居左,偶數居右

#endif // list_h_included

main.cpp

#include "list.h"

#include //移動結束後,奇數居左,偶數居右

void move(sqlist *&l)

} //待迴圈上去後,繼續查詢,並在必要時交換

}//用main寫測試**

int main()

; createlist(sq, a, 10);

printf("操作前 ");

displist(sq);

move(sq);

printf("操作後 ");

displist(sq);

return 0;

}

g.cpp

#include #include #include "list.h"

//用陣列建立線性表

void createlist(sqlist *&l, elemtype a, int n)

//初始化線性表initlist(l)

void initlist(sqlist *&l) //引用型指標

//銷毀線性表destroylist(l)

void destroylist(sqlist *&l)

//判定是否為空表listempty(l)

bool listempty(sqlist *l)

//求線性表的長度listlength(l)

int listlength(sqlist *l)

//輸出線性表displist(l)

void displist(sqlist *l)

//求某個資料元素值getelem(l,i,e)

bool getelem(sqlist *l,int i,elemtype &e)

//按元素值查詢locateelem(l,e)

int locateelem(sqlist *l, elemtype e)

//插入資料元素listinsert(l,i,e)

bool listinsert(sqlist *&l,int i,elemtype e)

//刪除資料元素listdelete(l,i,e)

bool listdelete(sqlist *&l,int i,elemtype &e)

執行結果:

知識點總結:

和(1)類似,利用多檔案組織和演算法庫,簡單方便。

心得體會:

熟練掌握多檔案組織,演算法庫,多練。

第三週專案四 順序表應用2

檔名稱 專案4.cpp 作 者 高金豔 完成日期 2016年9月14日 版 本 號 v1.0 問題描述 將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 重新排列後的線性表 標頭檔案list.h define maxsize 50 includ...

第三週 專案四 順序表應用 2

檔名稱 專案4.cbp 作 者 李瀟 完成日期 2016年9月17日 版 本 號 v1.0 問題描述 將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 輸入描述 無 程式輸出 輸出調整後的線性表 標頭檔案list.h ifndef list h included de...

第三週 專案四 順序表應用

問題描述及 完成日期 2016.9.17 問題描述 定義乙個採用順序結構儲存的線性表,設計演算法完成下面的工作 1 刪除元素在 x,y 之間的所有元素,要求演算法的時間複雜度為o n 空間複雜度為o 1 2 將所在奇數移到所有偶數的前面,要求演算法的時間複雜度為o n 空間複雜度為o 1 1.刪除元...