以前寫過一個純C的, 用的是數(shù)組,模擬C++ STL里面的set_intersection,set_union和set_difference的實現(xiàn)。 稍作了修改,添加了些注釋,希望能幫到你。注意:必須先對輸入集合排序;輸出結(jié)果和C++ STL的測試結(jié)果吻合。
創(chuàng)新互聯(lián)建站堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的番禺網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
“交:從一個集合中取出一個元素,在另一個集合中查找,如果有它就是交中的并:并也類似,關(guān)鍵就是判斷這個元素是否都在這兩個集合中出現(xiàn)。
b那段因為不知道你的else對應(yīng)誰,我就沒法看了。但是可以確認的一點是,你沒有考慮那些h2里面出現(xiàn)過,h1里面沒有出現(xiàn)過的數(shù)字。求c的那段,我就沒有看下去了。最后,強烈建議你采取面向?qū)ο蟮膶懛ā?/p>
那么,程序就可以簡化成,設(shè)數(shù)組key[52],用于記錄字母出現(xiàn)次數(shù)。掃描一次集合A,把出現(xiàn)的字母計到key的對應(yīng)位置里。同理掃描一次集合B。查看key數(shù)組,=2的對應(yīng)字母輸出到集合C,C就是所求交集。
用類似冒泡排序的算法,遍歷數(shù)組1中的第一個元素和數(shù)組2中每一個元素,若有相同的,則把這個元素放入第三個數(shù)組,繼續(xù)遍歷,知道數(shù)組1遍歷完所有元素,那數(shù)組3中的元素,即為兩個數(shù)組(集合)的交集。
1、只簡單地分析了一下交集的情況,求并集類似。百度知道這個代碼支持不怎么好,復(fù)制粘貼到 vs 之類的代碼編輯器里面縮進一下會比較好看。
2、fgets(a,fp);fgets(b,fv);fun(a,b);fputs(c,fs);fputs(d,fn);fputs(f,fn);fclose(fp);fclose(fv);fclose(fn);fclose(fs);} ps:懶得調(diào)試了,我剛學(xué)完C語言沒多久,還不是很行,望采納,我好升級,嘿嘿。
3、以前寫過一個純C的, 用的是數(shù)組,模擬C++ STL里面的set_intersection,set_union和set_difference的實現(xiàn)。 稍作了修改,添加了些注釋,希望能幫到你。注意:必須先對輸入集合排序;輸出結(jié)果和C++ STL的測試結(jié)果吻合。
4、用類似冒泡排序的算法,遍歷數(shù)組1中的第一個元素和數(shù)組2中每一個元素,若有相同的,則把這個元素放入第三個數(shù)組,繼續(xù)遍歷,知道數(shù)組1遍歷完所有元素,那數(shù)組3中的元素,即為兩個數(shù)組(集合)的交集。
5、那么,程序就可以簡化成,設(shè)數(shù)組key[52],用于記錄字母出現(xiàn)次數(shù)。掃描一次集合A,把出現(xiàn)的字母計到key的對應(yīng)位置里。同理掃描一次集合B。查看key數(shù)組,=2的對應(yīng)字母輸出到集合C,C就是所求交集。
交集就是兩個整數(shù)集合中,相同數(shù)組成的集合。
只簡單地分析了一下交集的情況,求并集類似。百度知道這個代碼支持不怎么好,復(fù)制粘貼到 vs 之類的代碼編輯器里面縮進一下會比較好看。
制作一個菜單,讓用戶在程序執(zhí)行時可以選擇:(1)求兩集合交集 (2)求兩集合并集 (3)求兩集合相減結(jié)果(如{1,2,3} - {1,4} = {2,3})該程序要用到函數(shù)的調(diào)用,數(shù)組做函數(shù)參數(shù)。
main()函數(shù)中, k,i沒有初始化就用作數(shù)組下表,這會產(chǎn)生問題,有可能造成數(shù)組越界錯誤。
在你給出的代碼中,找不到hc的定義,也就是說代碼不全。所以不進行全局代碼解釋 從題目中得到的信息是,找兩個集合的交集,用C語言的描述就是找數(shù)據(jù)的相同點的位置。
可以用線性表模擬集合,把兩個線性表中一樣的數(shù)提取出來就是交集,所有元素組成的就是并集,還可以用C++重載運算符實現(xiàn)+就求并集之類的。