Codeforces Round#413 Problem A - C
Problem#A Carrot Cakes
vjudge链接[here]
(偷个懒,cf链接就不给了)
题目大意是说,烤面包,给出一段时间内可以考的面包数,建第二个炉子的时间,需要达到的面包数,问建炉子是否合理。
玄学 & 智商题,可能是因为我智商不够,所以在我决定休息的时候被hank掉了。。。(纠正一个错误,是fst掉的)
输NO的情况大概是当炉子建好后,考完第一波的时间,任务已经或刚好完成。
Code
/** * Codeforces * Problem#799A * Accepted * Time:15ms * Memory:8k */ #include<iostream> #include<fstream> #include<sstream> #include<algorithm> #include<cstdio> #include<cstring> #include<cstdlib> #include<cctype> #include<cmath> #include<ctime> #include<map> #include<stack> #include<set> #include<queue> #include<vector> using namespace std; typedef bool boolean; #define inf 0xfffffff #define smin(a, b) (a) = min((a), (b)) #define smax(a, b) (a) = max((a), (b)) template<typename T> inline boolean readInteger(T& u) { char x; ; ); ) { ungetc(x, stdin); return false; } if(x == '-') { aFlag = -; x = getchar(); } + x - '); u *= aFlag; ungetc(x, stdin); return true; } int n, t, k, d; inline void work() { readInteger(n); readInteger(t); readInteger(k); readInteger(d); ; if(turns * k > n) puts("NO"); else if(turns * k == n && (d == t || turns * t <= d + t)) puts("NO"); else puts("YES"); } int main() { work(); ; }
Problem#A
Problem#B T-shirt buying
vjudge链接[here]
题目大意是说,每件衣服有两面,每面有个颜色,有些人要来买,他只买存在一面有他喜欢的颜色且价格最低的一个,输出每个人付的钱,没有买到输出-1。
用个set,依题意乱搞就好了。(每场比赛貌似都是b题稳AC)
Code
/** * Codeforces * Problem#799B * Accepted * Time:296ms * Memory:14964k */ #include<iostream> #include<fstream> #include<sstream> #include<algorithm> #include<cstdio> #include<cstring> #include<cstdlib> #include<cctype> #include<cmath> #include<ctime> #include<map> #include<stack> #include<set> #include<queue> #include<vector> using namespace std; typedef bool boolean; #define inf 0xfffffff #define smin(a, b) (a) = min((a), (b)) #define smax(a, b) (a) = max((a), (b)) template<typename T> inline boolean readInteger(T& u) { char x; ; ); ) { ungetc(x, stdin); return false; } if(x == '-') { aFlag = -; x = getchar(); } + x - '); u *= aFlag; ungetc(x, stdin); return true; } typedef class Tshirt { public: int p; int id; Tshirt() { } Tshirt(int p, int id):p(p), id(id) { } boolean operator < (Tshirt b) const { if(p != b.p) return p < b.p; return id < b.id; } }Tshirt; int n, m; int* prices; int *color1, *color2; multiset<Tshirt> ps[]; inline void init() { readInteger(n); prices = )]; color1 = )]; color2 = )]; ; i <= n; i++) readInteger(prices[i]); ; i <= n; i++) { readInteger(color1[i]); ps[color1[i] - ].insert(Tshirt(prices[i], i)); } ; i <= n; i++) { readInteger(color2[i]); if(color1[i] != color2[i]) ps[color2[i] - ].insert(Tshirt(prices[i], i)); } } inline void solve() { int c; readInteger(m); while(m--) { readInteger(c); c--; ) { printf("-1 "); } else { multiset<Tshirt>::iterator t = ps[c].begin(); printf("%d ", t->p); ) { ps[color1[t->id] - ].erase(ps[color1[t->id] - ].find(Tshirt(t->p, t->id))); } ) { ps[color2[t->id] - ].erase(ps[color2[t->id] - ].find(*t)); } ps[c].erase(t); } } } int main() { init(); solve(); ; }
Problem#B
Problem#C Fountains
vjudge链接[here]
C题思路不是很难,很好想,结果写炸了。。。
第一种情况,买两个不同购买方式的物品,贪心就好了。
第二种情况,买两个购买方式相同的物品,先按价格从小到大拍一道序,然后记录一个能延伸到的一个最远的物品r,每次i++时要用while循环去更新r,接着剩下的事交给线段树查最大值就好了。两种购买方式的物品都做一下就好了。
当然,写炸的缘故
1.自己坑自己。。sort的cmpare函数改了后没有改for循环的顺序(第一种情况比较懒,开始就写了就不想改了)
2.少特判当某种购买方式的物品不存在的情况,然后建树就挂了,MLE。
Code
/** * Codeforces * Problem#799C * Accepted * Time:62ms * Memory:6300k */ #include<iostream> #include<fstream> #include<sstream> #include<algorithm> #include<cstdio> #include<cstring> #include<cstdlib> #include<cctype> #include<cmath> #include<ctime> #include<map> #include<stack> #include<set> #include<queue> #include<vector> using namespace std; typedef bool boolean; #define inf 0xfffffff #define smin(a, b) (a) = min((a), (b)) #define smax(a, b) (a) = max((a), (b)) template<typename T> inline boolean readInteger(T& u) { char x; ; ); ) { ungetc(x, stdin); return false; } if(x == '-') { aFlag = -; x = getchar(); } + x - '); u *= aFlag; ungetc(x, stdin); return true; } typedef class MyPair { public: int c; int p; MyPair(, ):c(c), p(p) { } }MyPair; typedef class SegTreeNode { public: int val; SegTreeNode* l, *r; SegTreeNode():val(), l(NULL), r(NULL) { } inline void pushUp() { val = max(l->val, r->val); } }SegTreeNode; typedef class SegTree { public: SegTreeNode* root; SegTree() { } SegTree(int n, MyPair*& lis) { build(root, , n, lis); } void build(SegTreeNode*& node, int l, int r, MyPair*& lis) { node = new SegTreeNode(); if(l == r) { node->val = lis[l].c; return; } ; build(node->l, l, mid, lis); build(node->r, mid + , r, lis); node->pushUp(); } int query(SegTreeNode*& node, int l, int r, int ql, int qr) { ; if(l == ql && r == qr) { return node->val; } ; if(qr <= mid) return query(node->l, l, mid, ql, qr); , r, ql, qr); int a = query(node->l, l, mid, ql, mid); , r, mid + , qr); return max(a, b); } void clear(SegTreeNode*& node) { if(node->l) clear(node->l); if(node->r) clear(node->r); delete node; } }SegTree; int n; int C, D; MyPair *cs, *ds; , cnd = ; , bd = -; SegTree stc, stdd; inline void init() { readInteger(n); readInteger(C); readInteger(D); cs = )]; ds = )]; int a, b; char x; ; i <= n; i++) { readInteger(a); readInteger(b); getchar(); x = getchar(); if(x == 'C' && b <= C) cs[++cnc] = MyPair(a, b); else if(x == 'D' && b <= D) ds[++cnd] = MyPair(a, b); } } boolean cmp1(const MyPair& a, const MyPair& b) { if(a.c != b.c) return a.c > b.c; return a.p < b.p; } boolean cmp2(const MyPair& a, const MyPair& b) { if(a.p != b.p) return a.p < b.p; return a.c > b.c; } ; inline void solve() { ) sort(cs + , cs + cnc + , cmp1); ) sort(ds + , ds + cnd + , cmp1); ; i <= cnc; i++) if(cs[i].p <= C) { bc = cs[i].c; break; } ; i <= cnd; i++) if(ds[i].p <= D) { bd = ds[i].c; break; } && bd != -) res = bc + bd; ) sort(cs + , cs + cnc + , cmp2); ) sort(ds + , ds + cnd + , cmp2); int r = cnc; if(cnc) { stc = SegTree(cnc, cs); ; i <= r; i++) { , a1 = ; while(cs[i].p + cs[r].p > C) r--; if(i > r) break; ) a0 = stc.query(stc.root, , cnc, , i - ); if(i < cnc) a1 = stc.query(stc.root, , cnc, i + , r); && a1 == ) continue; smax(res, max(a0, a1) + cs[i].c); } } r = cnd; if(cnd) { stdd = SegTree(cnd, ds); ; i <= r; i++) { , a1 = ; while(ds[i].p + ds[r].p > D) r--; if(i > r) break; ) a0 = stdd.query(stdd.root, , cnd, , i - ); if(i < cnd) a1 = stdd.query(stdd.root, , cnd, i + , r); && a1 == ) continue; smax(res, max(a0, a1) + ds[i].c); } } printf("%d", res); } int main() { init(); solve(); ; }
Problem#C
Codeforces Round#413 Problem A - C的更多相关文章
- Codeforces Round #413 (Div1 + Div. 2) C. Fountains(树状数组维护最大值)
题目链接:https://codeforces.com/problemset/problem/799/C 题意:有 c 块硬币和 d 块钻石,每种喷泉消耗硬币或钻石中的一种,每个喷泉有一个美丽值,问建 ...
- codeforces Round 286# problem A. Mr. Kitayuta's Gift
Mr. Kitayuta has kindly given you a string s consisting of lowercase English letters. You are asked ...
- Playrix Codescapes Cup (Codeforces Round #413, rated, Div. 1 + Div. 2)(A.暴力,B.优先队列,C.dp乱搞)
A. Carrot Cakes time limit per test:1 second memory limit per test:256 megabytes input:standard inpu ...
- Educational Codeforces Round 21 Problem E(Codeforces 808E) - 动态规划 - 贪心
After several latest reforms many tourists are planning to visit Berland, and Berland people underst ...
- Educational Codeforces Round 21 Problem D(Codeforces 808D)
Vasya has an array a consisting of positive integer numbers. Vasya wants to divide this array into t ...
- Educational Codeforces Round 21 Problem A - C
Problem A Lucky Year 题目传送门[here] 题目大意是说,只有一个数字非零的数是幸运的,给出一个数,求下一个幸运的数是多少. 这个幸运的数不是最高位的数字都是零,于是只跟最高位有 ...
- Codeforces Round #413, rated, Div. 1 + Div. 2 C. Fountains(贪心 or 树状数组)
http://codeforces.com/contest/799/problem/C 题意: 有n做花园,有人有c个硬币,d个钻石 (2 ≤ n ≤ 100 000, 0 ≤ c, d ≤ 100 ...
- C.Fountains(Playrix Codescapes Cup (Codeforces Round #413, rated, Div. 1 + Div. 2)+线段树+RMQ)
题目链接:http://codeforces.com/contest/799/problem/C 题目: 题意: 给你n种喷泉的价格和漂亮值,这n种喷泉题目指定用钻石或现金支付(分别用D和C表示),C ...
- Educational Codeforces Round 32 Problem 888C - K-Dominant Character
1) Link to the problem: http://codeforces.com/contest/888/problem/C 2) Description: You are given a ...
随机推荐
- HDU - 5651 xiaoxin juju needs help 逆元模板
http://acm.hdu.edu.cn/showproblem.php?pid=5651 题意:生成回文串.输出所有回文串的可能数. 题解:mod除法会损失高位,用逆元来代替除法,模板如下 ac代 ...
- a new way of thinking about a problem
PHP Advanced and Object-Oriented Programming Larry Ullman The first thing that you must understand ...
- Common Gateway Interface Python CGI编程
https://en.wikipedia.org/wiki/Gateway_(telecommunications) In telecommunications, the term gateway r ...
- FW 编译Android系统源码和内核源码
编译Android系统源码和内核源码 分类: Android2014-07-21 20:58 7287人阅读 评论(28) 收藏 举报 好长时间没有写blog了,之所以没有写,主要还是工作上的事,发现 ...
- flask中的url_for
转自:https://blog.csdn.net/dengfan666/article/details/78320188 1.URL反转:根据视图函数名称得到当前所指向的url 2.url_for() ...
- javaScript设计模式(一)观察者模式
哈哈..写了一个钟,一点一点加功能. 1 function Publisher(){ this.subscribers = []; //存储订阅者 this.news = []; //存储要发布的消息 ...
- QQ公众号?是的,你没看错!
微信公众平台培育了800多万的微信公众号,自身也通过微信游戏.广告分销等找到了一些增值盈利模式.作为同门大师兄,qq也在11月份推出了QQ公众号,第一个手机QQ上的“生活服务号”——YTO圆通速递上线 ...
- 用Delphi写一个UTF8编码格式的文本文件
... var f: TextFile; begin AssignFile(f, 'test.txt'); Rewrite(f); write(f, #$EF+#$BB+#$BF); // UTF-8 ...
- 使用Navicat导入excel表
1:首先创建Navicat与数据库的连接 2:,从数据库中选择要导入的表 3:导入向导,选择要导入的数据类型 4:创创建excel表:一般第一行需要与表的属性相对应,这样就不需要手动设置对应栏位 不一 ...
- 纯代码实现WordPress上传图片自动重命名的方法
在我们使用 WordPress 发布文章时,经常都需要添加图片.多媒体什么的.然而,大家都知道 WordPress 是舶来物,对于中文用户来说,我们都会把图片命名为中文的,由于 WordPress 机 ...