拼多多第一题,按照要求输出了,结果只有40%

题中输出的小熊的饥饿值是按输入小熊的顺序输出的。
不知道C++中怎么做的这一点的。我用的方法只通过40%,应该是运行超时了。。
全部评论
用sort(begin,end,compare),排序两次。第一次按照战斗力排序,第二次按照编号排序。
点赞 回复 分享
发布于 2017-09-03 09:54
话说你sort的写法编译能通过?我也这么写的编译就过不去,只好手撸个冒泡排序。。。
点赞 回复 分享
发布于 2017-09-03 09:49
妹子刷题量惊人啊
点赞 回复 分享
发布于 2017-09-02 19:08
你是没按要求输出,题目要求按给的熊的顺序而不是排序后的熊的顺序
点赞 回复 分享
发布于 2017-09-02 19:02
用例中提供的数据是排序了的
点赞 回复 分享
发布于 2017-09-02 18:45
要按照原来输入小熊的顺序 输出相应的饥饿值
点赞 回复 分享
发布于 2017-09-02 18:21
#include<iostream> #include<vector> #include<algorithm> using namespace std; bool cmp(int a, int b) { return a > b; } bool cmp1(vector<int>a, vector<int>b) { return a[0] > b[0]; } int main() { int n, m; while (cin >> n >> m) { vector<int>a(m); //糖的能量值 for (int i = 0; i < m; i++) cin >> a[i]; vector<vector<int>>b(n,vector<int>(2)); //存储小熊的战斗力和饥饿值 for (int i = 0; i < n; i++) { for (int j = 0; j < 2; j++) { cin >> b[i][j]; } } sort(a.begin(), a.end(),cmp); vector<vector<int>>b1(b.begin(), b.end()); sort(b1.begin(), b1.end(), cmp1); vector<int>flag(m, 0); vector<int>res(n,0); //存储小熊剩余饥饿值 for (int i = 0; i < n; i++) { int j = 0; int tmp = b1[i][1]; while (j < m) { if (a[j] <= tmp && !flag[j]) { tmp = tmp - a[j]; flag[j] = 1; } j++; } res[i]=tmp; } for (int i = 0; i < n; i++) //输出 { int t = b[i][0]; for (int j = 0; j < n; j++) { if (b[j][0] == t) { cout << res[j] << endl; break; } } } } } 不知道为什么只通过了40%,思路应该没问题,我觉得应该是超时了。求大神指点。
点赞 回复 分享
发布于 2017-09-02 18:17
这个是我的代码, 也不知道怎么错. 同求高人指点. #include <iostream> #include <algorithm> #include <set> #include <vector> #include <stack> #include <set> #include <list> #include <bitset> #include <cstring> using namespace std; struct Bear { int fight; int hungry; }; int find_h(vector<Bear>& bears) { int i = 0; int h = -1; int idx = -1; while (i < bears.size()) { if (bears[i].hungry <= 0) { i++; continue; } if (h < bears[i].hungry) { h = bears[i].hungry; idx = i; } i++; } return idx; } void bear_eat(vector<Bear> &bears, int idx, vector<int>& suguars) { for (int i = suguars.size() - 1; i >= 0; i--) { if (suguars[i] == -1) continue; else if( suguars[i] > bears[idx].hungry) continue; else { bears[idx].hungry -= suguars[i]; suguars[i] = -1; break; } } } bool can_eat(vector<Bear> &bears, vector<int> &suguars) { vector<int> hs; for (int i = 0; i < bears.size(); i++) { if (bears[i].hungry > 0) { hs.push_back(bears[i].hungry); } } for (int i = 0; i < suguars.size(); i++) { if (suguars[i] > 0) for (auto& h: hs) if (suguars[i] <= h) return true; } return false; } void hdl(vector<Bear>& bears, vector<int>& suguars) { sort(suguars.begin(), suguars.end()); while (can_eat(bears, suguars)) { int most_h = find_h(bears); if (most_h == -1) break; bear_eat(bears, most_h, suguars); } } int main() { int n, m; cin >> n >> m; vector<int> suguars; for (int i = 0; i < m; i++) { int tmp; cin >> tmp; suguars.push_back(tmp); } vector<Bear> bears; for (int i = 0; i < n; i++) { int f = 0, h = 0; cin >> f >> h; bears.push_back({f, h}); } hdl(bears, suguars); for (int i = 0; i < bears.size() - 1; i++) cout << bears[i].hungry << endl; cout << bears[bears.size() - 1].hungry; return 0; }
点赞 回复 分享
发布于 2017-09-02 18:08

相关推荐

07-14 19:33
门头沟学院 Java
自我介绍(着重介绍与&nbsp;Java&nbsp;开发相关的项目和技能)​你对腾讯云智的产品有哪些了解?有没有使用过相关的服务?​Java&nbsp;中的集合框架有哪些?HashMap&nbsp;和&nbsp;ConcurrentHashMap&nbsp;的区别是什么?谈谈&nbsp;Java&nbsp;中的多线程,线程池的核心参数有哪些?如何设置合理的线程池参数?​Spring&nbsp;IoC&nbsp;和&nbsp;AOP&nbsp;的原理是什么?在项目中是如何使用&nbsp;AOP&nbsp;的?​Spring&nbsp;事务的传播机制有哪些?你在实际开发中遇到过哪些事务相关的问题​Java&nbsp;中&nbsp;synchronized&nbsp;和&nbsp;Lock&nbsp;的底层实现原理有何区别?谈谈你对偏向锁、轻量级锁、重量级锁的理解​深入分析&nbsp;ThreadLocal&nbsp;的内存泄漏问题,如何避免?在分布式场景下如何实现类似&nbsp;ThreadLocal&nbsp;的功能?​Redis&nbsp;的持久化机制有哪些?RDB&nbsp;和&nbsp;AOF&nbsp;的优缺点及适用场景是什么?如何解决&nbsp;AOF&nbsp;重写时的性能问题?​Redis&nbsp;的集群方案有哪些?哨兵模式和&nbsp;Cluster&nbsp;模式的区别是什么?Cluster&nbsp;模式下槽位迁移的过程是怎样的?​RabbitMQ&nbsp;的交换机类型有哪些?详细说明&nbsp;Topic&nbsp;交换机的路由规则,如何保证消息的可靠性投递(从生产者到交换机、交换机到队列、消费者消费三个环节分析)单例模式的实现方式有哪些?哪种方式是线程安全的?​在项目开发中,你是如何进行代码调试和排错的?有什么技巧吗?​工厂模式和抽象工厂模式的区别是什么?在什么场景下会使用抽象工厂模式?工厂模式在实际项目中有哪些应用?你觉得使用工厂模式有什么好处?​Java&nbsp;中的异常处理机制是怎样的?try-catch-finally&nbsp;块的执行顺序是什么?​谈谈你对&nbsp;Java&nbsp;内存模型的理解,volatile&nbsp;关键字的作用是什么?​数据库的分库分表有哪些方案?各自的优缺点是什么?​在进行&nbsp;Java&nbsp;开发时,你是如何保证代码质量的?会使用哪些工具?​做题​滑动窗口最大值
查看20道真题和解析
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务