第三週專案三 求集合並集

2021-07-22 17:53:08 字數 2960 閱讀 1567

/*  

* 檔名稱:專案3.cpp

* 作 者:高金豔

* 完成日期:2023年9月14日

* 版 本 號:v1.0

*問題描述:假設有兩個集合 a 和 b 分別用兩個線性表 la 和 lb 表示,

即線性表中的資料元素即為集合中的成員。設計演算法,用函式

unionlist(list la, list lb, list &lc )函式

實現該演算法,求乙個新的集合c=a∪b,即將兩個集合的並集放

*輸入描述:每個集合

*程式輸出:合併後的集合

*/

標頭檔案list.h

#define maxsize 50    

#include #include typedef int elemtype;

typedef struct

sqlist;

void unionlist(sqlist *la, sqlist *lb, sqlist *&lc);//求合集

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)

bool listdelete(sqlist *&l,int i,elemtype &e);//刪除資料元素listdelete(l,i,e)

原始檔list.cpp

#include "list.h"    

//求合集

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

lena=listlength(la); //求線性表la的長度

for (i=1; i<=listlength(lb); i++)

}

//以下為演算法庫功能函式

//用陣列建立線性表

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)

原始檔main.cpp

#include "list.h"    

//用main寫測試**

int main()

;

createlist(sq_a, a, 6);

printf("la: ");

displist(sq_a);

elemtype b[6]= ;

createlist(sq_b, b, 5);

printf("lb: ");

displist(sq_b);

unionlist(sq_a, sq_b, sq_c);

printf("lc: ");

displist(sq_c);

return 0;

}

執行結果:

知識點總結:

用演算法庫來解決問題。

學習心得:

通過這個專案我對多檔案運用自如了。

第三週專案三 求集合並集

檔名稱 求集合並集.cpp 作 者 王雪潔 完成日期 2015年 9月 版 本 號 問題描述 假設有兩個集合 a 和 b 分別用兩個線性表 la 和 lb 表示,即線性表中的資料元素即為集合中的成員。設計演算法,用函式unionlist list la,list lb,list lc 函式實現該演算...

第三週專案三 求集合並集

檔名稱 求集合並集.cpp 作 者 孫彩虹 完成日期 2015年 9月18日 版 本 號 問題描述 假設有兩個集合 a 和 b 分別用兩個線性表 la 和 lb 表示,即線性表中的資料元素即為集合中的成員。設計演算法,用函式unionlist list la,list lb,list lc 函式實現...

第三週 專案三 求集合並集

問題及 檔名稱 專案3 求集合並集.cpp 作 者 李瀟 完成日期 2016年9月11日 版 本 號 v1.0 問題描述 假設有兩個集合 a 和 b 分別用兩個線性表 la 和 lb 表示,即線性表中的資料元素即為集合中的成員。設計演算法,用函式unionlist list la,list lb,l...