Codeforces Round #413(Div. 1 + Div. 2, combined)——ABCD
题目在这里
A.Carrot Cakes
乱七八糟算出两个时间比较一下就行了
又臭又长仅供参考
#include <bits/stdc++.h>
#define rep(i, j, k) for(int i = j;i <= k;i ++)
#define rev(i, j, k) for(int i = j;i >= k;i --)
using namespace std;
typedef long long ll;
int main() {
    ios::sync_with_stdio(false);
    int n, t, k, d;
    cin >> n >> t >> k >> d;
    int t1 = (n + k - ) / k * t;
    int t2 = ;
    int t3 = (n + k - ) / k;
    int t4 = (d + t - ) / t;
    int t5 = t3 - t4;
    if(t5 & ) t2 = d + (t5 + ) /  * t;
    else t2 = t4 * t + t5 /  * t;
    if(t2 < t1) puts("YES");
    else puts("NO");
    return ;
}
B.T-shirt buying
颜色数只有三个,开三个优先队列就行了
然后同一件衣服不要重复卖
#include <bits/stdc++.h>
#define rep(i, j, k) for(int i = j;i <= k;i ++)
#define rev(i, j, k) for(int i = j;i >= k;i --)
using namespace std;
const int maxn = ;
typedef long long ll;
struct node {
    int x, y;
    bool operator < (const node &a) const {
        return x > a.x;
    }
};
priority_queue <node> q[];
int n, m, v[maxn], a, b, p[maxn];
int main() {
    ios::sync_with_stdio(false);
    cin >> n;
    rep(i, , n) cin >> p[i];
    rep(i, , n) cin >> a, q[a].push((node){p[i], i});
    rep(i, , n) cin >> b, q[b].push((node){p[i], i});
    cin >> m;
    rep(i, , m) {
        cin >> a;
        while(!q[a].empty() && v[q[a].top().y]) q[a].pop();
        if(!q[a].empty()) cout << q[a].top().x << " ", v[q[a].top().y] = , q[a].pop();
        else cout << "-1 ";
    }
    return ;
}
C.Fountains
三种情况,都用c或d买,一个c一个d
第三种肥肠简单的
前面两种的话
对于新插入的物品,如果价格为x
那么查询一下价格<=(c-x)的物品中的最大beauty
然后两个物品组合一下就行了
查询的话,直接树状数组就可以了,O(nlogn)
需要注意保证是两个不同物品,不能只有一个
 #include <bits/stdc++.h>
#define lb(x) (x & (-x))
#define rep(i, j, k) for(int i = j;i <= k;i ++)
#define rev(i, j, k) for(int i = j;i >= k;i --)
using namespace std;
typedef long long ll;
struct node{
    int x, y;
    char str[];
    void init() {
        scanf("%d %d %s", &x, &y, str);
    }
}a[];
int n, c, d, e, c1[], c2[];
int ask(int *C, int i) {
    int ret = ;
    while(i > ) ret = max(ret, C[i]), i -= lb(i);
    return ret;
}
void ins(int *C, int i, int x) {
    while(i <= e) C[i] = max(C[i], x), i += lb(i);
}
int main() {
    cin >> n >> c >> d, e = max(c, d);
    int t1 = , t2 = , t3, t4 = , t5 = , ans = ;
    rep(i, , n) {
        a[i].init();
        if(a[i].str[] == 'C' && a[i].y <= c) {
            if(a[i].x > t1) t1 = a[i].x;
            t3 = ask(c1, c - a[i].y);
            if(t3 !=  && a[i].x + t3 > t4) t4 = a[i].x + t3;
            ins(c1, a[i].y, a[i].x);
        }
        if(a[i].str[] == 'D' && a[i].y <= d) {
            if(a[i].x > t2) t2 = a[i].x;
            t3 = ask(c2, d - a[i].y);
            if(t3 !=  && a[i].x + t3 > t5) t5 = a[i].x + t3;
            ins(c2, a[i].y, a[i].x);
        }
    }
    ans = max(t4, t5);
    if(t1 !=  && t2 !=  && t1 + t2 > ans) ans = t1 + t2;
    cout << ans;
    return ;
}
我还肥肠脑残地,取消了cin与stdio的同步后
同时用cin和scanf,然后WA了一发...
D.Field expansion
显然ans最大就是loga级别的
所以我们直接暴搜就行了
然后考虑到很骚的情况
a = b = 10W h = w = 1
ai = 2 n = 10W
这样的话我们用map防重就好了
很重要的一件事情 :
注意到题意说能放下
所以并没有h一定对应a,w一定对应b
也可以试试h怼b,w怼a!
#include <bits/stdc++.h>
#define rep(i, j, k) for(int i = j;i <= k;i ++)
#define rev(i, j, k) for(int i = j;i >= k;i --)
using namespace std;
typedef long long ll;
int a, b, h, w, n, c[];
bool cmp(int x, int y) {
    return x > y;
}
typedef pair<ll, ll> node;
vector <node> e;
map <node,bool> p;
int main() {
    ios::sync_with_stdio(false);
    cin >> a >> b >> h >> w >> n;
    rep(i, , n) cin >> c[i];
    sort(c + , c + n + , cmp);
    node tmp;
    if(h >= a && w >= b || w >= a && h >= b) {puts("");return ;}
    e.push_back(make_pair(h, w));
    for(int i = ;i <= n;i ++) {
        int t = e.size();
        for(int j = ;j < t;j ++) {
            if(e[j].first < a) {
                tmp = make_pair(e[j].first * c[i], e[j].second);
                if(!p[tmp]) e.push_back(tmp), p[tmp] = ;
            }
            if(e[j].second < b) {
                tmp = make_pair(e[j].first, e[j].second * c[i]);
                if(!p[tmp]) e.push_back(tmp), p[tmp] = ;
            }
        }
        for(int j = ;j < e.size();j ++) {
            if(e[j].first >=  a && e[j].second >= b || e[j].first >=  b && e[j].second >= a) {
                cout << i;
                return ;
            }
        }
    }
    puts("-1");
    return ;
}
Codeforces Round #413(Div. 1 + Div. 2, combined)——ABCD的更多相关文章
- Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship
		Problem Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship Time Limit: 2000 mSec P ... 
- Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems(动态规划+矩阵快速幂)
		Problem Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems Time Limit: 3000 mSec P ... 
- Educational Codeforces Round 43 (Rated for Div. 2)
		Educational Codeforces Round 43 (Rated for Div. 2) https://codeforces.com/contest/976 A #include< ... 
- Educational Codeforces Round 35 (Rated for Div. 2)
		Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ... 
- Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings
		Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ... 
- Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes
		Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes 题目连接: http://code ... 
- Educational Codeforces Round 63 (Rated for Div. 2) 题解
		Educational Codeforces Round 63 (Rated for Div. 2)题解 题目链接 A. Reverse a Substring 给出一个字符串,现在可以对这个字符串进 ... 
- Educational Codeforces Round 39 (Rated for Div. 2) G
		Educational Codeforces Round 39 (Rated for Div. 2) G 题意: 给一个序列\(a_i(1 <= a_i <= 10^{9}),2 < ... 
- Educational Codeforces Round 48 (Rated for Div. 2) CD题解
		Educational Codeforces Round 48 (Rated for Div. 2) C. Vasya And The Mushrooms 题目链接:https://codeforce ... 
- Educational Codeforces Round 60 (Rated for Div. 2) 题解
		Educational Codeforces Round 60 (Rated for Div. 2) 题目链接:https://codeforces.com/contest/1117 A. Best ... 
随机推荐
- Mysql的简单使用(二)
			接上文Mysql的简单使用(一) 字段参数以“(字段名1 数据类型1,字段名2 数据类型2,......)”的形式构建. 关于mysql常用的数据类型,一下是比较常用的几种,想查阅比较详细的资料可以自 ... 
- getElementByTagName的使用
			<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ... 
- bzoj 1935 Tree 园丁的烦恼
			题目大意: 一些点,每次查询一个矩形内有多少个点 思路: 因为空间太大 所以不能用什么二维树状数组 需要把这些点和所有查询的矩阵的左下和右上离线下来 先离散化 然后每个子矩阵像二维前缀和那样查询 按照 ... 
- [CF391E2]Three Trees
			https://zybuluo.com/ysner/note/1246822 题面 有三棵树,建两条边让他们相连,最大化所有点对距离之和. \(40pts\ n\leq1000\) \(100pts\ ... 
- bzoj2194
			http://www.lydsy.com/JudgeOnline/problem.php?id=2194 卷积... 卷积并不高深,其实卷积就是两个多项式相乘的系数,但是得满足一点条件,就是f[n]= ... 
- NET运用String的十八层境界
			古往今来,文本处理一直是所有编程语言的最基础的功能,也是最核心最重要的功能.任何初学者,如果想学一门编程语言,都要面对大量的文本处理.而或许有一天,即使你成了大师级的人物,也不敢说自己驾驭文本处理的能 ... 
- 确定比赛名次(toposort)
			http://acm.hdu.edu.cn/showproblem.php?pid=1285 #include <stdio.h> #include <string.h> ; ... 
- [Swift通天遁地]八、媒体与动画-(5)使用开源类库绘制文字、图形、图像、图表、SVG(可缩放矢量图形)
			★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ... 
- Ubuntu下搭建repo服务器(三):   搭建Android repo服务器
			1. 配置repo 1.1 下载git-repo.git(B端) mkdir -p ~/gitCfg cd ~/gitCfg git clone https://gerrit.googlesourc ... 
- Mac使用bootcamp安装win8.1出现网卡驱动没有安装问题
			问题:没有网络连接 原因:在bootcamp烧的u盘里面其实附带了驱动,只是没有自动安装 解决:D:\BootCamp\Drivers\Broadcom\BroadcomWirelessWin8x64 ... 
