Programming 板


LINE

我不清楚這個問題是不是應該在此版發問,因為有點像演算法或資料結構的問題 如果不妥或違反板規我會立刻刪文! 問題是這樣的: 我現在有兩個set(集合),以array來實作,array中的元素沒有順序之分(因為是set) 其中set A 大小為M set B 大小為N M的大小遠大於N,其中M的大小約是N的平方倍 現在要寫一個演算法,創造一個set C,也是以array來實作 將A和B 聯集(Union)為C set 重點來了,此問題要求此演算法要盡量有效率 我的寫法如下:(虛擬碼) int main() { int a[1..M]; int b[1..N]; int[] c = merge(a,b,M,N); } int[] merge(int a[], int b[], int M, int N) { int S=M+N; int c[1..S]; //宣告C陣列,大小為M+N for(int i=1;i<=M;i++) //把a陣列丟進c的前半部 c[i]=a[i]; for(int i=1;i<=N;i++) //把b陣列丟進c的後半部 c[M+i]=b[i]; return c; } 這演算法就很直觀,也沒甚麼特別想法,就創一個M+N的array把元素都扔進來就對了 時間為O(N^2),因為M的大小相當於N^2 不知道有沒有更好的解決方法? 我實在不了解這問題有甚麼特殊之處,但感覺有陷阱 謝謝各位抽空幫我解答!! --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 60.244.44.20 ※ 編輯: flipsydee 來自: 60.244.44.20 (01/22 17:19) ※ 編輯: flipsydee 來自: 60.244.44.20 (01/22 17:20)
1F:→ jokester:"合併"是哪種操作? intersection? union?114.160.120.147 01/22 17:21
2F:→ jokester:這是c代碼嗎? 怎會返回一個棧上的指針@@114.160.120.147 01/22 17:22
是union 其實我程式底子沒很好....以上那些是虛擬碼,我的用意是回傳C陣列給主程式.. ※ 編輯: flipsydee 來自: 60.244.44.20 (01/22 17:25) 對不起,我好像發現問題了,既然是兩個set的union操作,應該要排除共同 的元素才是。那我以上的寫法都寫錯了... ※ 編輯: flipsydee 來自: 60.244.44.20 (01/22 17:28) ※ 編輯: flipsydee 來自: 60.244.44.20 (01/22 17:28)
3F:推 jokester:哈@@ 抱歉我看太快, 沒有看到是虛擬碼114.160.120.147 01/22 17:32
4F:→ jokester:可以把AB分別排序 再匯合到C114.160.120.147 01/22 17:34
5F:推 jokester:兩次排序和一次merge, 結果會有O(MlogM)114.160.120.147 01/22 17:36
6F:推 suhorng:這個merge沒處理重複的狀況... 118.166.51.235 01/22 21:36
我又寫了一個...網路上搜尋set union algorithm找到的資料很少... 只好自己寫了一個,可是很難看 版本一:為了省時間用線性時間排序與二分搜尋法 https://github.com/vacuumv/coding1/blob/master/test.c 版本二:網路上有人說可以用hashing table的想法去寫,又沒給code 所以我也自作聰明的寫了一個 https://github.com/vacuumv/coding1/blob/master/test2.c 小弟的程式概念很薄弱,還望大家不吝賜教......有錯的很誇張的觀念 也請多多包涵... 我只是在想這種常見的問題應該會有固定解法阿(最好的演算法)...有人知道嗎? ※ 編輯: flipsydee 來自: 60.244.44.20 (01/22 22:11)
7F:推 suhorng:因為比較多是不限定用什麼實作set吧 118.166.51.235 01/22 22:28
8F:→ suhorng:例如用hash table代表set, 然後去討論各種 118.166.51.235 01/22 22:28
9F:→ suhorng:操作的時間複雜度之類. 118.166.51.235 01/22 22:28
10F:推 singlovesong:沒仔細看題目 不過set union不是課 140.109.16.164 01/23 09:26
11F:→ singlovesong:本裡面有最佳算法嗎 140.109.16.164 01/23 09:26
12F:→ singlovesong:path compression union by rank? 140.109.16.164 01/23 09:26
那個好像是disjoint set的union才適用喔.. 現在題目給的兩個set 可能非disjoint.. 其實這是台大資管所102年計算機概論的題目~貼上原文,大家可以思考一下! Design an algorithm that, given two sets of numbers, computes the union of the two sets. The first set of m numbers is given as an array A in no particular order and the second set of n numbers as another array B also in no particular order. The result should be represented as a third array C where no particular ordering is required. It is known that m is much larger than n, approximately in the order of n^2. Please describe your algorithm in suitable pseudo code and analyze its time complexity. The more efficient your algorithm is, the more points you will be credited for this problem.(15%) ※ 編輯: flipsydee 來自: 60.244.44.20 (01/23 11:14)
13F:推 yvb:test1.c 的 radixsort(), 註解的 O(1) 是?? 118.168.219.47 01/24 13:07
14F:→ yvb:test2.c 若 M=100, N=10, A[0]=1000 會怎樣? 118.168.219.47 01/24 13:09
15F:推 singlovesong:最慘就Mlog(M)吧, balanced tree硬做140.109.135.106 01/24 15:09
16F:→ singlovesong:題目這樣出應該是要想Mlog(N)的解140.109.135.106 01/24 15:10







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BabyMother站內搜尋

TOP