CF #575 Div3
// 比赛链接:https://codeforces.com/contest/1196
// CF 2019.7.24
// 本想Div3手速场上分,结果卡在C题,掉了不少分。
// 自闭了这么久,今天补题,吸取教训。
A - Three Piles of Candies
题意:
比赛时候看了半天也没看明白,真是sb了。
Alice与Bob要把三堆糖果尽可能地平分,两人轮流拿,最后一个拿的要保证两人一样多。否则的话如果最后谁多了就要扔掉,直到两人拿的糖果数量相等。
给定三堆糖果初始数量,求他们能平分到的最多糖果数量。
题解:
三个数求和 / 2 就是答案。(奇数相当于向下取整了)
AC代码:
略。
B - Odd Sum Segments
题意:
有 n 个数字 a1,a2,…… an,要把他们分割成 k 段,每段和都为奇数。若能实现,输出YES和划分情况,否则输出NO。
题解:
显然 ai 为偶数对每段的和没有贡献,只要统计奇数个数不少于 k 且多余的奇数和为偶数就能完成划分。
从前往后扫一遍即可。(注意格式,我都服气WA了五次。。。心态炸裂)
AC代码:(补题时候头脑怎么如此清醒2min就写好1A???)
#include<cstdio>
#include<iostream>
using namespace std;
typedef long long ll; ll a[]; int main() {
int q; cin>>q;
while(q--) {
int n, k;
int cnt = ; // 奇数个数
scanf("%d %d", &n, &k);
for(int i=;i<=n;i++) {
scanf("%lld", &a[i]);
if(a[i]%) ++cnt;
} if(cnt<k || (cnt-k)%==) {
printf("NO\n");
continue;
} printf("YES\n");
for(int i=;i<=n && k>;i++) {
if(a[i]%==) {
printf("%d ", i);
--k;
}
}
printf("%d\n", n); // 最后一段 n 结尾 }
return ;
}
C - Robot Breakout
题意:
平面上有 n 个机器人,机器人可以上下左右四个方向移动,但机器人出了问题,只具备其中某些方向移动的能力。给出 n 个机器人的坐标及可以移动的方向,求出 n 个机器人都可以抵达的一点(X, Y)。
题解:
分析一下可知,机器人能向上移动时,(x, y+n)都能抵达;机器人能向下移动时,(x, y-n)都能抵达;对 x 方向同理。
所以比赛时候我sb地把能到的区域求交(而忽略了不能到的区域)。
反过来想:
用不能走到的区域更新能到的区域。(默认能到达平面上全部点)
初始时,取down = left = -INF,up = right = INF,全部平面上的点(x, y) 满足 down <= x <= up,left <= y <= right,用四个边界来表示。
加入一个机器人,某个方向不能移动则与边界值求交(同小取小,同大取大)。
AC代码:
#include<cstdio>
#include<iostream>
using namespace std;
typedef long long ll; int main() {
int q; cin>>q;
while(q--) {
int n;
int x, y, left, right, up, down;
int minX = -;
int maxX = ;
int minY = -;
int maxY = ; // 题目规定了平面大小,就不要设更大的值 scanf("%d", &n);
while(n--) {
scanf("%d %d %d %d %d %d", &x, &y, &left, &up, &right, &down); if(!left)
minX = max(minX, x);
if(!right)
maxX = min(maxX, x);
if(!up)
maxY = min(maxY, y);
if(!down)
minY = max(minY, y);
}
if(minX<=maxX && minY<=maxY)
printf("1 %d %d\n", minX, minY);
else
printf("0\n");
}
return ;
}
D1 - RGB Substring (easy version)
题意:
将一个含有RGB字母的字符串改变最少的字符使其包含字符串“RGBRGB..."的长度为 k 的子串,求改动的字符数量最小值。
题解:
easy版本字符串的长度不超过3000,暴力就能解决。(枚举 s 串起点终点记录改变数量)
AC代码:
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
char s[];
char p[] = "RGBRG";
int main() {
int q; cin>>q;
while(q--) {
int n, k;
scanf("%d %d", &n, &k);
scanf("%s", s); int len = strlen(s);
int ans = 0x3f3f3f3f;
for(int i=;i+k<=len;i++) {
for(int st=;st<;st++) {
int now = ;
for(int kk=;kk<k;kk++) {
if(s[i+kk]!=p[st+kk%]) ++now;
}
ans = min(ans, now);
}
}
printf("%d\n", ans);
}
return ;
}
D2 - RGB Substring (hard version)
题意:
同上一题,长度更新为 n<= 2e5。
题解:
简单dp。
记录每一位不同后,只需要滑动长度为 k 的串,改动数量由 dp[i+1],dp[i-k]处的变化更新。
AC代码:(RE一次忘记开大内存了)
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
char s[];
char p[] = "RGBRG"; int dp[][];
int main() {
int q; cin>>q;
while(q--) {
int n, k;
scanf("%d %d", &n, &k);
scanf("%s", s); int len = strlen(s);
for(int st=;st<;st++) {
for(int i=;i<len;i++) {
dp[st][i] = (s[i]!=p[st+i%]);
}
} int ans = 0x3f3f3f3f;
for(int st=;st<;st++) {
int now = ;
for(int i=;i<k;i++) {
now += dp[st][i];
}
ans = min(ans, now);
for(int i=k;i<len;i++) {
now += dp[st][i];
now -= dp[st][i-k];
ans = min(ans, now);
}
}
printf("%d\n", ans);
}
return ;
}
// 补题不超过20分钟能A,比赛能保持这速度就好了 O.O
E - Connected Component on a Chessboard
题意:
文化差异方面的原因吗?看半天也看不懂题。
看了别人博客的题目说明,原来是要在国际象棋上选 b个黑色格子,w 个白色格子(满足全部格子连通的条件)。给出b + w 个格子的坐标。
题解:
一个白色格子有4个黑色相邻,两个白色格子有4+3个相邻,n 个白色格子有 3*n + 1 个黑色格子相邻。
所以只要 b <= 3*w + 1 或者 w <= 3*b + 1 就能构造出解。
AC代码:
#include<cstdio>
#include<iostream>
using namespace std;
// 原题 b == black w == white
// 潜意识里b当做白块了,读取交换了w,b的含义
int main() {
int q; cin>>q;
while(q--) {
int add = ;
int b, w;
scanf("%d %d", &w, &b);
if(b>w) {
swap(b, w);
add = ;
} if(w>*b+) {
printf("NO\n");
continue;
} printf("YES\n");
for(int i=;i<=b;i++) { // 白块
printf("%d %d\n", +add, i*);
}
for(int i=;i<=b && w;i++) { // 黑块>=白块,放左右两边
printf("%d %d\n", +add, i*+);
--w;
}
for(int i=;i<=b && w;i++) { // 黑块放白块上面
printf("%d %d\n", +add, i*);
--w;
}
for(int i=;i<=b && w;i++) { // 黑块放白块下面
printf("%d %d\n", +add, i*);
--w;
}
}
return ;
}
F - K-th Path
题意:
给出一个无向图,求图上所有路径中第 k 长的长度。
题解:
突破口是 k 的范围,k = min(n*(n+1)/2, 400),k 不超过400。
可以想到,第 k 短路至少在 边权第 k 大的边上,所有边权排在400以后的对图上两点最短路没有任何贡献。
只需要记录前 k 条边的节点,利用Floyd算法跑两点间的最短路即可。
AC代码:
#include<cstdio>
#include<iostream>
#include<vector>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long ll; ll dis[][];
int n, m, k;
struct Edge {
int u, v;
ll w;
bool operator<(const Edge& a)const {
return w<a.w;
}
}edge[];
vector<int> node; int main() {
cin>>n>>m>>k;
for(int i=;i<m;i++) {
scanf("%d %d %lld", &edge[i].u, &edge[i].v, &edge[i].w);
}
sort(edge, edge+m); for(int i=;i<min(m, k);i++) {
node.push_back(edge[i].u);
node.push_back(edge[i].v);
} // 离散化
sort(node.begin(), node.end());
node.resize(unique(node.begin(), node.end())-node.begin()); memset(dis, 0x3f, sizeof(dis));
for(int i=;i<min(m, k);i++) {
int x = lower_bound(node.begin(), node.end(), edge[i].u)-node.begin();
int y = lower_bound(node.begin(), node.end(), edge[i].v)-node.begin();
dis[x][y] = dis[y][x] = min(dis[x][y], edge[i].w);
} // Floyd
for(int l=;l<node.size();l++) {
for(int i=;i<node.size();i++) {
for(int j=;j<node.size();j++) {
dis[i][j] = min(dis[i][j], dis[i][l]+dis[l][j]);
}
}
} // 注意 i,j 不能重复, j = i + 1
vector<ll> ans;
for(int i=;i<node.size();i++) {
for(int j=i+;j<node.size();j++) {
ans.push_back(dis[i][j]);
}
} sort(ans.begin(), ans.end());
printf("%lld\n", ans[k-]); return ;
}
(End)
CF #575 Div3的更多相关文章
- CF #552 div3
A - Restoring Three Numbers CodeForces - 1154A Polycarp has guessed three positive integers aa, bb a ...
- 2021-01-25 cf #697 Div3 C题(超时,换思路减少复杂度)
题目链接:https://codeforces.com/contest/1475/problem/C 题意要求:需组成的2对,男的序号不能重,女的序号不能重 比如这例 输入: 行1--测试个数 行1` ...
- 12.27 cf div3 解题报告
12.27 cf div3 解题报告 wxy.wxy,带上分拉,全场做了个无脑小白 比赛场地 A: T1,跟着模拟就好了 B: sort一遍之后 去除的数一定是a[1]或者a[n] 比较去除谁小就输出 ...
- Codeforces Round #575 (Div. 3) 昨天的div3 补题
Codeforces Round #575 (Div. 3) 这个div3打的太差了,心态都崩了. B. Odd Sum Segments B 题我就想了很久,这个题目我是找的奇数的个数,因为奇数想分 ...
- CF #552(div3)G 最小lcm
题目链接:http://codeforces.com/contest/1154/problem/G 题意:lcm是最小公倍数,本题就是给你一个数组(可能会重复),要求你判断出那两个数的最小公倍数最小, ...
- CF #552(div3)F 背包问题
题目链接:http://codeforces.com/contest/1154/problem/F 题意:一个商店有n个物品,每个物品只能买一次,同时有m种优惠,即一次买够x件后,这x件中最便宜的k件 ...
- CF contest 1216 Div3. F
题目链接:Click here Solution: 看起来是贪心,其实不然... 我们定义\(f[i]\)表示仅覆盖\(1\sim i\)所需要的最小代价,那么对\(i\)为0的点来说,易得\(f[i ...
- Codeforces Round #535 (Div. 3) [codeforces div3 难度测评]
hhhh感觉我真的太久没有接触过OI了 大约是前天听到JK他们约着一起刷codeforces,假期里觉得有些颓废的我忽然也心血来潮来看看题目 今天看codeforces才知道居然有div3了,感觉应该 ...
- 一句话CF
目录 \(\bf {Round \ \#500 \ (Div. \ 1)}\) \(\bf {Round \ \#589 \ (Div. \ 2)}\) \(\bf {Avito \ Cool \ C ...
随机推荐
- Pathfinding 模板题 /// BFS oj21413
题目大意: Description Bessie is stranded on a deserted arctic island and wants to determine all the path ...
- ES6 学习 -- 解构赋值
一.数组解构 **数组解构,解构出来的值跟数组下标是一一对应的,如果左边变量多于右边数组,则左边后面部分变量值为undefined,如果右边数组元素个数多于左边解构变量个数,则左边变量全都有值,且一一 ...
- linux命令输出到屏幕的同时保存到文件
有时候无法在一个屏幕中打印出所有显示内容 可以使用以下命令: ifconfig | tee ifconfig.log more ifconfig.log
- 【笔记篇】单调队列优化dp学习笔记&&luogu2569_bzoj1855股票交♂易
DP颂 DP之神 圣洁美丽 算法光芒照大地 我们怀着 崇高敬意 跪倒在DP神殿里 你的复杂 能让蒟蒻 试图入门却放弃 在你光辉 照耀下面 AC真心不容易 dp大概是最经久不衰 亘古不化的算法了吧. 而 ...
- 深度探索C++对象模型之第二章:构造函数语意学之Default constructor的构造操作
C++新手一般由两个常见的误解: 如果任何class没有定义默认构造函数(default constructor),编译器就会合成一个来. 编译器合成的的default constructor会显示的 ...
- python的异常捕捉
你可能会说既然有万能异常Exception,那么我直接用上面的这种形式就好了,其他异常可以忽略 你说的没错,但是应该分两种情况去看 1.如果你想要的效果是,无论出现什么异常,我们统一丢弃,或者使用同一 ...
- Android开发 SeekBar开发记录
前言 开发记录博客不是讲解使用博客,更多的是各种功能与点子的记录 基本使用 <SeekBar android:layout_width="match_parent" andr ...
- VS2010-MFC(MFC常用类:MFC异常处理)
转自:http://www.jizhuomi.com/software/236.html 上一节讲了CFile文件操作类,本节主要来说说MFC异常处理. 在鸡啄米C++编程入门系列的最后一节鸡啄米:C ...
- 杂项-日志:日志(log)
ylbtech-杂项-日志:日志(log) 1.返回顶部 1. 概述 网络设备.系统及服务程序等,在运作时都会产生一个叫log的事件记录:每一行日志都记载着日期.时间.使用者及动作等相关操作的描述. ...
- System.Web.Mvc.HttpPostAttribute.cs
ylbtech-System.Web.Mvc.HttpPostAttribute.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, ...