CSSE 板


LINE

※ 引述《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, 找到Y阵列中的另一格值$yhash{$num-$item}. 接下来有个问题是:$yhash{$num-$item}是Y的第几格? 在这个情况中,看起来没有处理这个... 而是否没处理这个让你得到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长度. 是哪种情况呢? --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 218.160.109.178







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

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

TOP