C_and_CPP 板


LINE

问题(Question): 题目输入有三种指令 PUSH k //把k加到heap POP //删除heap中的最小值 TOP //输出heap中的最小值 我直接使用 priority_queue<int, vector<int>, greater<int>> 可以AC 但是如过我仍然使用 priority_queue<int>, 也就是max heap 然後在push资料时push -k进去, pop时再列印出负值, 逻辑上应该也可以达到min-heap的效果, 但是有两笔测资一直过不了, 就算换成long long也是一样, 想请问是哪里有bug,谢谢大家! 这是这题的oj网址 https://acm.cs.nthu.edu.tw/problem/12316/ 程式码(Code):(请善用置底文网页, 记得排版,禁止使用图档) 这是有两笔测资过不了的程式码 http://codepad.org/VvfpJVDk #include <iostream> #include <queue> #include <string> using namespace std; int main(int argc, const char * argv[]) { priority_queue<long long> q; string cmd; long long num; while (cin >> cmd) { if (cmd == "PUSH") { cin >> num; q.push(-num); } else if (cmd == "POP" && !q.empty()) { q.pop(); } else if (cmd == "TOP"){ if (q.empty()) { cout << "Null" << endl; } else { cout << -q.top() << endl; } } } return 0; } --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 140.114.222.158 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1559739424.A.53D.html
1F:推 cutekid: -2147483648 ? 06/05 21:33
2F:推 Sylveon: TA 的测资有 -2147483648 欧XD 06/05 22:28
3F:推 Sylveon: 经确认 2/5 侧资有非预期的内容,会在更正後重新rejudge 06/05 23:04
4F:→ engine210: 欧欧欧所以是测资有其他问题吗xd,想说long long 应该 06/06 00:14
5F:→ engine210: 就不会有溢位的问题了可是还是过不了 06/06 00:14
6F:→ Lipraxde: 如果啊,用 -(k+1),是不是就不用担心溢位了? 06/06 01:43
7F:→ RishYang: 用long long 应该要可以AC 06/06 07:47
8F:推 cutekid: 推 Lipraxde →-(k+1) 06/06 12:37
9F:→ engine210: -(k+1)试过了也不行qq 06/06 15:23
10F:推 LPH66: 不要写成 -(k+1) 这样会先加 1 再负还是一样 06/06 23:09
11F:→ LPH66: 用 ~k 就可以了, 这个是 bitwise not 06/06 23:09
12F:→ LPH66: 不过这其实不是正常写法, 还是明确指定比较函数比较好 06/06 23:10
13F:推 xavier13540: 猜测你只有把容器的int改成long long -x本身还是int 06/07 01:30
14F:→ xavier13540: 当x=INT_MIN时 -x=INT_MIN 容器装long long也没用 06/07 01:33
15F:推 Fenikso: 测资有问题.. 那原po用min-heap是怎麽过的 XD 06/07 02:10
16F:→ RishYang: @xavier13540我测过这个问题,很神秘的还是会错 06/07 08:35
17F:→ kevin4314: 感觉是测资爆int 06/07 17:59







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

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

TOP