Codeforces Round #193 (Div. 2) 部分题解
A:直接判断前三项是否相等
int main()
{
//FIN;
//CHEAT;
int n;
cin>>n;
getchar();
char a[];
gets(a);
int len = strlen(a);
int cnt = ;
for(int i = ; i < len ; i++)
{
if(i % n == && i != )
{
if(a[i-] == a[i-] && a[i-] == a[i-])
cnt++;
}
}
cout<<cnt<<endl;
return ;
}
B:
求一遍前缀和O(n).... 用前缀和求一遍所有长度为k的区间和O(n)....
再从后往前找一遍这些区间的最大值O(n)...并记下从该点到最后的区间最大值...
然后就从前向后遍历一遍,每次找从i开始的区间和从点i+k之后的最大区间 ,求一次MAX即可 O(n)
总共还是O(n)...用线段树什么的就别逗了
LL a[];
LL sum[];
LL sum1[];
LL max2[];
LL maxe[];
int main()
{
//FIN;
//CHEAT;
int n,k;
cin>>n>>k;
for(int i = ; i <= n ; i++)
{
cin>>a[i];
sum[i] = sum[i-] + a[i];
}
int cnt = ;
for(int i = ; i <= n-k+ ; i++)
{
sum1[cnt++] = sum[i+k-] - sum[i-];
}
int back = cnt-;
LL M = -INF;
for(int i = cnt- ; i >= ; i--)
{
if(sum1[i] >= M)
{
max2[i] = sum1[i];
maxe[i] = i;
M = sum1[i];
}else
{
max2[i] = M;
maxe[i] = maxe[i+];
}
}
M = -INF;
int s1=,s2=;
for(int i = ; i <= n ; i++)
{
if(max2[i+k] + sum1[i] > M)
{
M = max2[i+k] + sum1[i];
s1 = i;
s2 = maxe[i+k];
}
}
cout<<s1<<" "<<s2<<endl;
return ;
}
C:
先贪心找 b最小a最大的 这是有可能取的任务
再贪心找 a最大b最大的 这是一定取的k个任务,并求出最小值
再贪心从剩下的点中 找出b小于最小值的点 ,再贪心找取p-k个b最大a最小的点...
排三遍序就行了...挺麻烦而且我感觉数据弱了...
struct point
{
int id ;
int s,v;
}x[MAXN],q[MAXN];
int cmp(point a,point b)
{
if(a.v != b.v)
return a.v < b.v;
else return a.s > b.s;
}
int cmp1(point a,point b)
{
if(a.s != b.s)
return a.s > b.s;
else return a.v > b.v;
}
int cmp2(point a,point b)
{
if(a.v != b.v)
return a.v > b.v;
else return a.s < b.s;
}
int main()
{
//FIN;
//CHEAT;
int n,p,k;
cin>>n>>p>>k;
for(int i = ; i < n ; i++)
{
cin>>x[i].s>>x[i].v;
x[i].id = i;
}
sort(x,x+n,cmp);
sort(x+(p-k),x+n,cmp1);
// for(int i = 0 ; i < n ; i++)
// cout<<x[i].s<<" "<<x[i].v<<" "<<x[i].id+1<<endl;
// cout<<endl;
int M = INF;
for(int i = p-k ;i < p ; i++)
M = min(M,x[i].v);
int cnt = ;
for(int i = ; i < p - k ; i++)
q[cnt++] = x[i];
for(int i = p- ; i < n ; i++)
if(x[i].v < M )
q[cnt++] = x[i];
sort(q,q+cnt,cmp2); for(int i = p-k ; i < p ; i++)
cout<<x[i].id+<<" ";
for(int i = ; i < p - k ; i++)
cout<<q[i].id+<<" ";
cout<<endl;
return ;
}
都是赛后做的...赛中做的话又要掉rating真是难过...今天多校也爆0...真是弱的不能多说...
Codeforces Round #193 (Div. 2) 部分题解的更多相关文章
- # Codeforces Round #529(Div.3)个人题解
Codeforces Round #529(Div.3)个人题解 前言: 闲来无事补了前天的cf,想着最近刷题有点点怠惰,就直接一场cf一场cf的刷算了,以后的题解也都会以每场的形式写出来 A. Re ...
- Codeforces Round #557 (Div. 1) 简要题解
Codeforces Round #557 (Div. 1) 简要题解 codeforces A. Hide and Seek 枚举起始位置\(a\),如果\(a\)未在序列中出现,则对答案有\(2\ ...
- Codeforces Round #540 (Div. 3) 部分题解
Codeforces Round #540 (Div. 3) 题目链接:https://codeforces.com/contest/1118 题目太多啦,解释题意都花很多时间...还有事情要做,就选 ...
- Codeforces Round #538 (Div. 2) (A-E题解)
Codeforces Round #538 (Div. 2) 题目链接:https://codeforces.com/contest/1114 A. Got Any Grapes? 题意: 有三个人, ...
- Codeforces Round #531 (Div. 3) ABCDEF题解
Codeforces Round #531 (Div. 3) 题目总链接:https://codeforces.com/contest/1102 A. Integer Sequence Dividin ...
- Codeforces Round #527 (Div. 3) ABCDEF题解
Codeforces Round #527 (Div. 3) 题解 题目总链接:https://codeforces.com/contest/1092 A. Uniform String 题意: 输入 ...
- Codeforces Round #499 (Div. 1)部分题解(B,C,D)
Codeforces Round #499 (Div. 1) 这场本来想和同学一起打\(\rm virtual\ contest\)的,结果有事耽搁了,之后又陆陆续续写了些,就综合起来发一篇题解. B ...
- Codeforces Round #545 (Div. 1) 简要题解
这里没有翻译 Codeforces Round #545 (Div. 1) T1 对于每行每列分别离散化,求出大于这个位置的数字的个数即可. # include <bits/stdc++.h&g ...
- Codeforces Round #624 (Div. 3)(题解)
Codeforces Round #624 (Div.3) 题目地址:https://codeforces.ml/contest/1311 B题:WeirdSort 题意:给出含有n个元素的数组a,和 ...
随机推荐
- POJ 1258 Agri-Net (最小生成树+Prim)
Agri-Net Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 39820 Accepted: 16192 Descri ...
- Thumb指令集与ARM指令集的差别
Thumb指令集 Thumb指令能够看做是ARM指令压缩形式的子集.是针对代码密度[1]的问题而提出的.它具有16为的代码密度.Thumb不是一个完整的体系结构,不能指望处理程序仅仅 ...
- 3.菜鸟教你一步一步开发 web service 之 axis 服务端创建
转自:https://blog.csdn.net/shfqbluestone/article/details/37610601 第一步,新建一个工程,如图: 选 Java 写一个工程名,选择好工程路径 ...
- hashCode 和 equals 方法
hashCode 和 equals 方法 hashCode()和equals()定义在Object类中,这个类是所有java类的基类,所以所有的java类都继承这两个方法. 使用hashCode()和 ...
- Tomcat部署项目修改浏览器上猫咪头像
一.发现问题用tomcat部署项目,在浏览器标签也上发现了tomcat猫咪图.要把这个图修改掉. 二.解决问题apache-tomcat-5.5.28\webapps\ROOT下的ico文件,将需要替 ...
- 发现javax.xml.parsers.SAXParser有bug
javax.xml.parsers.SAXParser有bug, 我发现的地方在characters(char[] ch, int start, int length) length偶尔会变小,导致截 ...
- cf 865 B. Ordering Pizza
B. Ordering Pizza It's another Start[c]up finals, and that means there is pizza to order for the ons ...
- GHO文件内IE主页的修改方法
修改方法: 1.先打开映像 GHOSTexp 打开GHO文件 2.提取注册表文件 C:\WINDOWS\SYSTEM32\CONFIG 下就是系统的注册表文件,详细见下 3.打开本地的注册表,加载 ...
- BZOJ5408: string(广义后缀自动机,LCT)
传送门 解题思路: 首先在后缀树上,确定了一个节点就相当于确定了一个串,那么一个点对应的串在另外一个点对应的串产生贡献,当且仅当这个点在当前点子树内. 那么考虑一个新的点在串中对串答案的贡献在一条树链 ...
- 紫书 习题 10-16 UVa 1647 (高精度+递推)
这道题我已经推出00和1过两步变成00了,可我没有继续做下去-- 后来看了博客发现自己已经做了90%了-- 可惜了,以后不要轻易放弃. 1的个数有个规律,就是每次都乘以2,因为0和1下一步都会变出1 ...