CSSE 板


LINE

※ 引述《yauhh (哟)》之铭言: : ※ 引述《dryman (dryman)》之铭言: : : 用Perl随便兜一个 : : 虽然这不能当演算法的解答啦 : : 不过就应用上还蛮不错的XD : : @x = 1..60; : : @y = 30..100; : : $num = 50; : : @xhash{@x}=0..$#x; : : @yhash{@y}=0..$#y; : : foreach $item (@x) { : : push @pair,[$xhash{$item},$yhash{$num-$item}] if exists $yhash{$num-$item}; : : } : 看你这一段程式有些小小疑惑,就当做hash真强到找什麽都O(1)好了, : 先考虑一种情况: : 首先把X,Y阵列的值都丢到xhash和yhash, : 你找到一个$xhash{$item},$item表示X阵列的一格值,所以用$num-$item找yhash, 这行看不懂 我是对@x做回圈 foreach $item (@x) 可读作 for each $item in @x array : 找到Y阵列中的另一格值$yhash{$num-$item}. : 接下来有个问题是:$yhash{$num-$item}是Y的第几格? hash 中没有格不格的问题啊@ @ $yhash{$num-$item} 是把$num-$item的值 丢进" if exists $yhash " 中 (这句不适合拆开来读,因为$yhash在前面有exists时是回传布林值 没有exists 时则是回传此键对应的值) 这一步的动作为O(1) : 在这个情况中,看起来没有处理这个... 而是否没处理这个让你得到O(n)的印象? : 考虑另一种情况: : 也许我不懂perl,把它看错了,其实是把X,Y阵列的每一格,包含{index,value}都丢进 : hash. 所以$xhash{$item}是{i,v}这样的内容,把它拿去yhash找的时候, : 一定要做两个动作: : 1. 把v取出找$num-v : 2. 在yhash找到合适的{j,$num-v}. : 然後你才可以找到一对(i,j),其X[i]与Y[j]总和为$num. : 在这种情况中,找到对应的{j,$num-v}显然不会是O(1)的,假设有k个这种j, : 就要找j次. 这样算总数起码也是个O(m*k),m是X长度,k可视同为Y长度. : 是哪种情况呢? 我想您可能是看错foreach $item (@x) 这一行吧XD 後面这里的解释我都看不太懂:P --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 220.136.185.230
1F:→ dryman:突然发现原始题目是exist i,j 而不是找全部的解... 05/10 00:47
@yhash{@y} = 0..$#y; for $item (@x){ print "exist\n" if exists $yhash{$num-$item}; } XDDDDD 超级有"语感"的!! Perl是语言学家开发出来的程式语言用起来真的抄酷! ※ 编辑: dryman 来自: 220.136.185.230 (05/10 00:49)
2F:→ yauhh:可是你找答案是要告知是在Y的第几格. 05/10 00:52
3F:→ yauhh:你用yhash随便存一个值能有什麽用呢? 05/10 00:52
4F:→ yauhh:总之,我认为你没有找到少於O(m*n)的演算法,你只是把程式写出 05/10 00:55
5F:→ yauhh:来而已. 05/10 00:55
6F:→ yauhh:你想想看,我在演算法观点上写第二段,你随便说看不懂,那麽, 05/10 00:56
7F:→ yauhh:你随便丢出一段perl码,谁有必要看得懂? 05/10 00:57
8F:→ yauhh:我也可以说我把X包装成new some(X),然後它找任何值以及由值 05/10 01:01
9F:→ yauhh:找任何index全是O(1)...但那没意义,这是在谈演算法,不是程式 05/10 01:02
10F:→ dryman:你真的懂hash是什麽吗?... = = 05/10 01:02
11F:→ yauhh:我懂啊,但你知不知道我没在跟你谈hash 05/10 01:03
12F:→ dryman:经由hash function来确认是否有值本来就是O(1) 05/10 01:03
13F:→ yauhh:我在跟你讲的是,虽然你找得到值,但没找到对应於值的index.. 05/10 01:04
14F:→ dryman:我的key->arr val, value-> arr idx 05/10 01:04
15F:→ yauhh:可是这问题没有解决啊,又不是你hash弄完就把答案弄出来了 05/10 01:04
16F:→ dryman:这样就可以找到idx了啊 05/10 01:04
17F:→ dryman:push @pair, [$xhash{$item},$yhash{$num-$hash}] 05/10 01:05
18F:→ yauhh:对啊,问的就是这个啊 05/10 01:06
19F:→ dryman:这不就是用$item及$num-$item当hash key来找arr idx 05/10 01:06
20F:→ dryman:我最後面补充的,是因为原始题目是问i,j是否exists 05/10 01:07
21F:→ dryman:所以可以写得非常短...印出exist就好 05/10 01:07
22F:→ yauhh:ok,下一个问题是,如果一个value对应到好几个index,取这一堆 05/10 01:09
23F:→ yauhh:也是O(1)? 05/10 01:09
24F:→ dryman:噢,我的解法是假设X,Y的值都是unique 05/10 01:11
25F:→ dryman:在个别阵列中不会有重复的值,这我的确没考虑到 05/10 01:11
26F:→ yauhh:那你不可以假设,题目并没有假设这件事情. 05/10 01:12
27F:→ dryman:不过用hash还是可以解:利用hash做出值不重复的阵列 05/10 01:13
28F:→ dryman:同时记录每个value的index(用hash of array) 05/10 01:13
29F:→ dryman:做出不重复的阵列後再用本解法得出arr val,用hash of arr 05/10 01:14
30F:→ dryman:反推idx 05/10 01:14
31F:→ dryman:这样的话就是some small value * O(n) 05/10 01:15
32F:→ dryman:明早还有课,先不战了XD 05/10 01:16
33F:→ dryman:明天再来PO改版的城市 05/10 01:16







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