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,和 ...
随机推荐
- Node.js的helloworld 程序
用文本编辑器.如npp,键入例如以下代码.存储成hello.js console.log('hello') console.log('hello %s->%d','jeapedu', 19418 ...
- Vue进阶之表单控件绑定
1.单行input <html> <head> <meta charset="UTF-8"> <meta name="viewp ...
- org.mybatis.spring.mapper.MapperScannerConfigurer$Scanner$1
不能加载或找不到 org.mybatis.spring.mapper.MapperScannerConfigurer$Scanner$1 经查证,是mybatis-spring-xxx.jar 这个版 ...
- HDU 4431 Mahjong 模拟
http://acm.hdu.edu.cn/showproblem.php?pid=4431 不能说是水题了,具体实现还是很恶心的...几乎优化到哭但是DFS(还加了几个剪枝)还是不行...搜索一直T ...
- chgrp---改变文件或目录所属的用户组
chgrp命令用来改变文件或目录所属的用户组.该命令用来改变指定文件所属的用户组.其中,组名可以是用户组的id,也可以是用户组的组名.文件名可以 是由空格分开的要改变属组的文件列表,也可以是由通配符描 ...
- 【editplus经常用的快捷键】Editplus 选中一行ctrl+r,Edit 合并行 Ctrl+Shift+J 合并选定行 删除当前行
Editplus 选中一行: ctrl+rEditplus 复制一行: ctrl+r选择行,然后ctrl+c复制.复制一行到下一行中:Editplus有:Ctrl+j 复制上一行的一个字符到当前行Ed ...
- ASP.NET通过JavaScript实现Button 的Enabled=false
正常代码控制无法满足需求,所以记录一下方法: <input id="Button5" onclick=" CX()" type="button& ...
- cocos2d-x的声音控制
声音控制SimpleAudioEngine是单例.下面是其方法. [cpp] view plaincopy //获得SimpleAudioEngine的实例 static SimpleAudioEng ...
- js---17继承中方法属性的重写
function F(){}; var f = new F(); f.name = "cf"; f.hasOwnProperty("name");//true ...
- C#接口,类,集成
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...