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灯, 水草

请输入看板名称,例如:WOW站内搜寻

TOP