Educational Codeforces Round 110 (Rated for Div. 2) (AB签到,C题双指针,D题DP好题)
补题链接:Here
1535A. Fair Playoff
四名选手参加了季后赛。比赛按以下方案进行:第一名选手与第二名选手比赛,第三名选手与第四名选手比赛,然后两人中的获胜者进入决赛。
众所周知,在两个选手之间的比赛中,技术更高的一个将获胜。第 \(i\) 位玩家的技能等于 \(s_i\) ,所有技能等级两两不同(i。 e。数组中没有两个相同的值。
如果两位技术最高的选手在决赛中相遇,这场比赛就被称为公平。
确定给定的比赛是否公平。
先进行比较,确定出线玩家的技能值大小,然后排序进行最终比较,如果技能值和相等则输出 YES
,否则输出 NO
void solve() {
int a[4];
cin >> a[0] >> a[1] >> a[2] >> a[3];
int b = max(a[0], a[1]), c = max(a[2], a[3]);
sort(a, a + 4);
// cout << b << " " << c << " " << a[0] << " " << a[1] << "\n";
if (a[2] + a[3] == b + c)cout << "YES\n";
else cout << "NO\n";
}
1535B. Array Reodering
好下标数对
:\(1\le i < j \le n\) 并且 \(gcd(a_i,2a_j) > 1\)
请问在给定的大小为 \(n\) 的数组可重排序后的最大好下标数对
的数量
如果 \(a_i\) 的值为偶数,那么 \(gcd(a_i,2a_j)\) 的值至少为 \(2\) 并且不必去考虑 \(a_j\) 的值,所以我们只需要把原数组的偶数放前面,奇数放后面即可
void solve() {
int n; cin >> n;
vector<int>a, b;
for (int i = 0, x; i < n; ++i) {
cin >> x;
if (x & 1)a.push_back(x);
else b.push_back(x);
}
vector<int>v;
for (int x : b)v.push_back(x);
for (int x : a)v.push_back(x);
int cnt = 0;
for (int i = 0; i < n; ++i)
for (int j = i + 1; j < n; ++j)
if (__gcd(v[i], 2 * v[j] ) > 1)cnt++;
cout << cnt << "\n";
}
更新一发 H神 的写法:Lamda表达式,233ms -> 200ms
void solve() {
int n; cin >> n;
vector<int>a(n);
for (int &x : a)cin >> x;
sort(a.begin(), a.end(), [](const int &x, const int &y) {
return x % 2 < y % 2;
});
int ans = 0;
for (int i = 0; i < n; ++i)
for (int j = i + 1; j < n; ++j)
ans += __gcd(a[i], 2 * a[j]) > 1;
cout << ans << "\n";
}
1535C. Unstable String
给你一个字符串s,定义如果一个字符串任意两个位置符号都不同,且只有0,1组成的字符串是不稳定的。
定义由0,1,?,组成的字符串,且?可以任意的转换成0和1,使字符串可以变成不稳定的字符串叫做美丽字符串。
给一个字符串求有多少子字符串可以形成美丽的字符串。
假如有一个区间 \([l,r]\) ,如果这个区间内的字符串是美丽的,那以r结尾的美丽子字符串的贡献就是 r-l+1
我们每次让右指针向右遍历,如果当前区间是美丽字符串,那以 \(r\) 结尾的子符串产生的贡献就是 r-l+1
,如果遍历的过程中当前的字符串不是美丽字符串,那我们就让左指针向右。
但是我们怎么判断当前的区间是不是美丽的呢?
我们判断一个字符串是不是美丽的,其实只需要判断当前区间是不是只有奇数位置上有一种字符,偶数位置上是另一种字符,?
号的时候可以忽略,因为有 ?
可以变成奇数和偶数,不会影响判断。
记得答案要开 long long
。
因为如果是全是 ?
的串,最终的结果是 \(n*(n+1)/ 2\) 是会超出 int
的
void solve() {
string s;
cin >> s;
int type = 0, cnt = 0;
ll ans = 0;
for (int i = 0, j = 0; i < s.size(); ++i) {
while (j < s.size()) {
if (s[j] == '?')j++;
else if (cnt == 0 or type == (s[j] - '0') ^ (j % 2)) {
cnt++;
type = (s[j] - '0') ^ (j % 2);
j++;
} else break;
}
ans += j - i;
if (s[i] != '?')cnt--;
}
cout << ans << "\n";
}
1535D. Playoff Tournament
【题意待补】
代码来自 H神,学习ing....
void solve() {
int k; string s;
cin >> k >> s, s = " " + s;
vector<int>par(1 << k), L(1 << k), R(1 << k), f(1 << k);
for (int i = 1, x = 1, y = (1 << (k - 1)) + 1; i < k; ++i) {
for (int j = 0; j < (1 << (k - i)); ++j) {
par[j + x] = j / 2 + y;
(j & 1 ? R : L)[j / 2 + y] = j + x;
}
x = y;
y += (1 << (k - 1 - i));
}
auto up = [&](int i) {
f[i] = 0;
if (i <= (1 << (k - 1)))f[i] = 1 + (s[i] == '?');
else {
if (s[i] != '1')f[i] += f[L[i]];
if (s[i] != '0')f[i] += f[R[i]];
}
};
for (int i = 1; i < (1 << k); ++i)up(i);
int _; for (cin >> _; _--;) {
int p; string c;
cin >> p >> c;
for (s[p] = c[0] ; p; p = par[p])up(p);
cout << f.back() << "\n";
}
}
Educational Codeforces Round 110 (Rated for Div. 2) (AB签到,C题双指针,D题DP好题)的更多相关文章
- Educational Codeforces Round 90 (Rated for Div. 2) D. Maximum Sum on Even Positions(dp)
题目链接:https://codeforces.com/contest/1373/problem/D 题意 给出一个大小为 $n$ 的数组 $a$,下标为 $0 \sim n - 1$,可以进行一次反 ...
- Educational Codeforces Round 89 (Rated for Div. 2) B. Shuffle(数学/双指针)
题目链接:https://codeforces.com/contest/1366/problem/B 题意 大小为 $n$ 的数组 $a$,除了 $a_x = 1$,其余 $a_i = 0$,依次给出 ...
- 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 < ...
随机推荐
- 【Android】关于去标题栏 | 有的时候代码有效有的时候无效
原因就在于你的manifest.xml的theme指向谁? 一开始我的theme指向这个↑,所以就改了好多也没用 之后改成这个↓就好了
- class-dump 混淆加固、保护与优化原理
class-dump 混淆加固.保护与优化原理 进行逆向时,经常需要dump可执行文件的头文件,用以确定类信息和方法信息,为hook相关方法提供更加详细的数据.class-dump的主要用于检查存 ...
- MongoDB的聚合笔记
1,聚合 聚合(aggregate)主要用于计算数据,类似sql中的sum().avg(). 常用的表达式如上图. 1.1,aggregate 语法 语法: db.集合名称.aggregat ...
- springboot下添加全局异常处理和自定义异常处理
前言 在spring项目中,优雅处理异常,好处是可以将系统产生的全部异常统一捕获处理,自定义的异常也由全局异常来捕获,如果涉及到validator参数校验器使用全局异常捕获也是较为方便. 相关代码: ...
- shell 脚本中的 '-f' 和 '-d' 分别代表什么意思
shell脚本中,'-f' 和 '-d'是用于测试文件类型的条件表达式. 1.'-f'表达式: 表达式: '[ -f file ]' 描述: 判断给定路径是否是一个常规文件 (regular file ...
- 有了Excel和PPT,为什么我们还需要数据可视化工具?
在当今信息时代,数据扮演着越来越重要的角色,而数据的可视化呈现正是一种强大的工具,能够帮助我们更好地理解和利用这些数据.虽然Excel和PPT在处理数据方面有着不可否认的作用,但在处理大规模.复杂数据 ...
- Json Schema简介和Json Schema的.net实现库 LateApexEarlySpeed.Json.Schema
什么是Json Schema ? Json Schema是一种声明式语言,它可以用来标识Json的结构,数据类型和数据的具体限制,它提供了描述期望Json结构的标准化方法. 利用Json Schema ...
- R6900 R7000刷梅林 AImesh组网
本文作者: Colin本文链接: https://www.colinjiang.com/archives/netgear-r6900-flash-merlin-rom.html 然后开始讲正题,刷梅林 ...
- Linux的一些的常用命令
小杰笔记: 记录一下Linux的一些常见命令: 1:Linux关机与重启的命令: shutdown:关机 shutdown -h 30 30秒后关机 reboot 重启 sync:将数据由内存同步到硬 ...
- Not on FX application thread(八)
Not on FX application thread(八) JavaFX 从入门到入土系列 当你不在主线程中操作UI时会出现以下异常: Not on FX application thread 可 ...