codeforces 799 C. Fountains(二分+思维)
题目链接:http://codeforces.com/contest/799/problem/C
题意:要求造2座fountains,可以用钻石,也可以用硬币来造,但是能用的钻石有限,硬币也有限,问能造出最大的美丽值为多少。
题解:显然如果两个fountains分别用钻石和硬币来造的话就直接取两种类型里满足条件的最大值即可。
如果选的是同类的话,先按照数量来排序,然后那一个数量为基准二分下个可行的数量,然后还需要一个
数组来存小于等于某个数量的最大美丽值。
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long ll;
const int M = 1e5 + 10;
ll a[5] , b[M] , p[M] , CM[M] , DM[M];
char cp[M][3];
struct TnT {
ll pr , be;//pr表示需要多少原料,be表示美丽值为多少
}C[M] , D[M];
bool cmp(int x , int y) {
return x > y;
}
bool cmp1(TnT x , TnT y) {
return x.pr < y.pr;//按照原料量排序
}
ll binsearch(TnT x[] , int l , int r , ll val) {
while(l <= r) {
int mid = (l + r) >> 1;
if(val < x[mid].pr) {
r = mid - 1;
}
else {
l = mid + 1;
}
}
return l;
}
int main() {
ll n , c , d;
ll M1 = -1 , M2 = -1;
cin >> n >> c >> d;
for(int i = 0 ; i < n ; i++) {
cin >> b[i] >> p[i] >> cp[i];
}
for(int i = 0 ; i < n ; i++) {
if(cp[i][0] == 'C' && p[i] <= c) M1 = max(M1 , b[i]);
if(cp[i][0] == 'D' && p[i] <= d) M2 = max(M2 , b[i]);
}
ll sum = 0;
if(M1 != -1 && M2 != -1) {
sum = M1 + M2;//表示各造一种
}
int cnt1 = 0 , cnt2 = 0;
for(int i = 0 ; i < n ; i++) {
if(cp[i][0] == 'C') {
C[cnt1].be = b[i] , C[cnt1].pr = p[i];
cnt1++;
}
else {
D[cnt2].be = b[i] , D[cnt2].pr = p[i];
cnt2++;
}
}
sort(C , C + cnt1 , cmp1);
sort(D , D + cnt2 , cmp1);
memset(CM , -1 , sizeof(CM));
CM[0] = C[0].be;
for(int i = 1 ; i < cnt1 ; i++) {
CM[i] = max(CM[i - 1] , C[i].be);//pr为有序记录小于等于pr的最大美丽值。
}
for(int i = cnt1 - 1 ; i >= 1 ; i--) {
ll gg = c - C[i].pr;
int pos = binsearch(C , 0 , i - 1 , gg);
if(pos != 0) {
sum = max(sum , C[i].be + CM[pos - 1]);
}
}
memset(DM , -1 , sizeof(DM));
DM[0] = D[0].be;
for(int i = 1 ; i < cnt2 ; i++) {
DM[i] = max(DM[i - 1] , D[i].be);
}
for(int i = cnt2 - 1 ; i >= 1 ; i--) {
ll gg = d - D[i].pr;
int pos = binsearch(D , 0 , i - 1 , gg);
if(pos != 0) {
sum = max(sum , D[i].be + DM[pos - 1]);
}
}
cout << sum << endl;
return 0;
}
codeforces 799 C. Fountains(二分+思维)的更多相关文章
- codeforces 895B XK Segments 二分 思维
codeforces 895B XK Segments 题目大意: 寻找符合要求的\((i,j)\)对,有:\[a_i \le a_j \] 同时存在\(k\),且\(k\)能够被\(x\)整除,\( ...
- [Codeforces 1199C]MP3(离散化+二分答案)
[Codeforces 1199C]MP3(离散化+二分答案) 题面 给出一个长度为n的序列\(a_i\)和常数I,定义一次操作[l,r]可以把序列中<l的数全部变成l,>r的数全部变成r ...
- codeforces E. Mahmoud and Ehab and the function(二分+思维)
题目链接:http://codeforces.com/contest/862/problem/E 题解:水题显然利用前缀和考虑一下然后就是二分b的和与-ans_a最近的数(ans_a表示a的前缀和(奇 ...
- codeforces 814 C. An impassioned circulation of affection(二分+思维)
题目链接:http://codeforces.com/contest/814/problem/C 题意:给出一串字符串然后q个询问,问替换掉将m个字符替换为字符c,能得到的最长的连续的字符c是多长 题 ...
- codeforces 808 E. Selling Souvenirs (dp+二分+思维)
题目链接:http://codeforces.com/contest/808/problem/E 题意:最多有100000个物品最大能放下300000的背包,每个物品都有权值和重量,为能够带的最大权值 ...
- codeforces 799 D. Field expansion(dfs+思维剪枝)
题目链接:http://codeforces.com/contest/799/problem/D 题意:给出h*w的矩阵,要求经过操作使得h*w的矩阵能够放下a*b的矩阵,操作为:将长或者宽*z[i] ...
- Codeforces Round #409 C. Voltage Keepsake(二分+思维)
题目链接:http://codeforces.com/contest/801/problem/C 题意:给出一个充电器每秒钟充p个点,还有n个电器要同时使用a[i]表示第i个电器每秒钟用多少点,b[i ...
- codeforces 985 D. Sand Fortress(二分+思维)
Sand Fortress time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...
- Codeforces 975 前缀和二分算存活人数 思维离直线速度相同判平行
A /* Huyyt */ #include <bits/stdc++.h> using namespace std; typedef long long ll; ]; ]; map< ...
随机推荐
- 【部分转载】:【lower_bound、upperbound讲解、二分查找、最长上升子序列(LIS)、最长下降子序列模版】
二分 lower_bound lower_bound()在一个区间内进行二分查找,返回第一个大于等于目标值的位置(地址) upper_bound upper_bound()与lower_bound() ...
- MySQL 之 Explain 输出分析
MySQL 之 Explain 输出分析 背景 前面的文章写过 MySQL 的事务和锁,这篇文章我们来聊聊 MySQL 的 Explain,估计大家在工作或者面试中多多少少都会接触过这个.可能工作中 ...
- 简洁明了的Noip考场策略 / 平时做题也适用
1.选择策略: 评估的标准得分的难度不是AC的难度 2.思考问题: 怀疑的眼光审视自己 3.写代码前: 想想可不可以换一种代码实现会好写很多 把自己的思路再理一遍,可以写到纸上,记下来大致关键顺序 4 ...
- Kubernetes Pod 驱逐详解
原文链接:Kubernetes Pod 驱逐详解 在 Kubernetes 中,Pod 使用的资源最重要的是 CPU.内存和磁盘 IO,这些资源可以被分为可压缩资源(CPU)和不可压缩资源(内存,磁盘 ...
- 2019牛客多校训练第四场K.number(思维)
题目传送门 题意: 输入一个只包含数字的字符串,求出是300的倍数的子串的个数(不同位置的0.00.000等都算,并考虑前导零的情况). sample input: 600 1230003210132 ...
- 有关element 的一些问题(随时更新)
<el-input></el-input> input 组件中官方自带的change时间是监听失去焦点之后的value变化,要想一只监听value的值变化的话需要使用 @i ...
- flask项目部署到云服务器+域名绑定
一.效果演示 首页展示 播放页面 该项目部署只为学习,所以用的服务器是腾讯云服务器10元/月,域名也是在腾讯云买的.com 55元/年 因为本人比较穷 哈哈
- Javasrcipt中从一个url或者从一个字符串中获取参数值得方法
从url中获取参数值是che程序开发过程中的常用需求,偶然得闲,便抽空研究了一下javasrcipt下,获取参数的办法(JAVA中也类似). 首先看url的规范: URL组成:protocol :// ...
- 在一个jsp页面内实现简单计算器
首先创建一个calculate.jsp 这是用Javascript代码来验证,代码如下: <script type="text/javascript"> functio ...
- python历史背诵
一.python简介 python2:源代码不统一 有重复功能的代码 默认编码是ascii 没有中文 输出中文需要用头文件 #-*-coding=utf-8-*- 进行转换 py3:源代码统一 没有重 ...