Prob_Solve 板


LINE

※ 引述《RockLee (Now of all times)》之铭言: : 原始网址: : http://www.careercup.com/question?id=14539805 : 题目: : Three strings say A, B, C are given to you. : Check weather 3rd string is interleaved from string A and B. : Ex: A="abcd" B="xyz" C="axybczd". answer is yes. o(n) : 用 Dynamic Programming 应该可在 O(n^2) 的时间内解决 : 但要在 O(n) 的时间内解决就想不出来了 Orz... : CareerCup 上的讨论看来都无法在 O(n) 的时间内正确的解决 : 不知道板上有没有人有什麽 idea? 这题不能直接这样做吗? 1. 将A, B, C分别放进stackA, stackB, stackC 2. 以下列函数判别答案是否为真 bool foo() { while ( stackC is not empty ) { if ( top of stackC == top of stackA ) { pop stackC; pop stackA; } else if (top of stackC == top of stackB ) { pop stackC; pop stackB; } else { return false; } } return true; } -- 直接阅读《琴剑六记》 http://gs.cathargraph.com/p/list.html   《琴剑六记》Facebook专页 https://www.facebook.com/GSannals --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 180.176.10.104
1F:→ flere:当top stack of C跟top A,B一样的时候,无法判断pop哪一个 03/29 18:05
2F:→ flere:stack才会是正确的~ 03/29 18:05
3F:→ pnpncat:咦@@ 是这样吗? 不是随便pop哪一个都一样吗? 我把code里 03/29 21:12
4F:→ pnpncat:面的A B对调 应该还是会得到同样的结果吧 03/29 21:13
5F:→ flere:A=ab,B=ac,C=acab,你看到第一个a的时候,如果popA的a的话 03/29 21:21
6F:→ flere:等等看到c就会找不到对应的了(还是我误会了吗??XDD 03/29 21:21
7F:→ pnpncat:了解了^^" 03/29 21:21
8F:→ pnpncat:是我想错XD 03/29 21:22
9F:→ pnpncat:等等 不对啊 这样等下会找到c啊........... 03/29 21:23
10F:→ pnpncat:那时候c就在stackB上面不是吗? 03/29 21:24
11F:→ pnpncat:我刚重想了一下 这算法应该是没错的 就跟没有盖牌的接龙 03/29 21:25
12F:→ pnpncat:道理一样 不可能会接不起来吧 03/29 21:25
13F:→ flere:可是这时候stackB最上面会是a耶,如果你说最上面会是c的话, 03/29 22:03
14F:→ flere:那我改成A=ba,B=ca,C=baca 03/29 22:04
15F:→ flere:因为pop a同时有两个stack符合,所以会不确定pop哪个stack才 03/29 22:05
16F:→ flere:对~ 03/29 22:05
17F:→ pnpncat:确实耶@@ 虽然直接用A往下搜到完也能解 但就不是O(n)了... 03/29 23:46
18F:→ pnpncat:看来还是要多用一个容器 把没有match的依序存起来才行 03/29 23:54
我多加一个空的queue做做看 bool foo() { while (stackC is not empty) { if (top of stackC == top of stackA) { pop stackC; pop stackA; } else { enqueue(top of stackC); pop stackC; } } if (stackA is not empty) return false; while (queue is not empty) { if (head of queue == top of stackB) { dequeue; pop stackB; } else { return false; } } return true; } 这样就还是 O(n)......... 这次有想错吗?? ※ 编辑: pnpncat 来自: 180.176.10.104 (03/30 00:14)
19F:推 ledia:"accc", "bcbc", "abcccbcc" 03/31 02:12
20F:→ pnpncat:看来是我把它想得太简单了@@ 03/31 22:54







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

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

TOP