Educational Codeforces Round 160 (Rated for Div. 2)
A
直接模拟,注意细节
#include<bits/stdc++.h>
#define ll long long
using namespace std;
ll p[15] = {1};
void solve() {
ll x;
cin >> x;
int len = 0;
while(x / p[len + 1]) ++ len;
for(int i = 1; i <= len; ++ i) {
ll a = x / p[i];
ll b = x % p[i];
if(b >= p[i - 1] && b > a) {
return cout << a << ' ' << b << '\n', void();
}
}
cout << "-1\n";
}
int main() {
for(int i = 1; i <= 10; ++ i) p[i] = p[i - 1] * 10;
int T;
cin >> T;
while(T --) solve();
return 0;
}
B
一道很直观的贪心,用总共的0和1去构造答案,一旦失败,输出答案
void solve() {
string s;
cin >> s;
int cnt[2] = {0, 0};
for(auto ch : s) cnt[1] += ch == '1', cnt[0] += ch == '0';
for(int i = 0; i < s.length(); ++ i) {
if(s[i] == '0') {
if(-- cnt[1] < 0) return cout << s.length() - i << '\n', void();
}
else if(-- cnt[0] < 0) {
return cout << s.length() - i << '\n', void();
}
}
cout << "0\n";
}
C
开一个\(f\)数组统计某一位出现的次数
注意第\(i\)位能被两个\(i - 1\)位合成
检验时从低到高位遍历,同时计算\(f\)数组内部低位对高位的贡献
#include<bits/stdc++.h>
using namespace std;
int f[40], g[40];
bool check(int x) {
memcpy(g, f, sizeof f);
for(int i = 0; i <= 30; ++ i) {
if(x >> i & 1) {
if(g[i]) {
g[i + 1] += (g[i] - 1) / 2;
}
else return 0;
}
else g[i + 1] += g[i] / 2;
}
return 1;
}
int main() {
ios :: sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
int m;
cin >> m;
while(m --) {
int op, x;
cin >> op >> x;
if(op == 1) ++ f[x];
else {
cout << (check(x) ? "YES" : "NO") << '\n';
}
}
return 0;
}
D. Array Collapse
考虑分治。
设 \(f[l, r]\) 为区间 \([l, r]\) 能够通过操作得到的子序列数。
设 \([l, r]\) 内最小元素的下标为 \(p\)。
如果只考虑 \([l, r]\) 内部的所有情况,因为无论怎么操作 \(a[p]\) 都无法被删除,所以有 \(f[l][r] = f[l][p - 1] \cdot f[p + 1][r]\)。
考虑外部元素对 \(f[l][r]\) 的贡献。
显然,任意一个比 \(a[p]\) 大的数都不能使 \([l,r]\) 内有新的子序列出现。
如果 \(\exists i < l\),\(a[i] < a[p]\),那么我们可以把 \([l,p]\) 删掉,剩下 \([p + 1, r]\),新贡献为 \(f[p + 1][r]\)。
如果 \(\exists j > r\),\(a[j] < a[p]\),那么我们可以把 \([p,r]\) 删掉,剩下 \([l, p - 1]\),新贡献为 \(f[l][p - 1]\)。
如果上述 \(i,j\) 都存在,我们发现两者重复计算了 \([l,r]\) 全部删掉的方案,则 \(f[l][r]\) 减一。
考虑递归边界。
如果 \(l > r\),只存在空集这一种方案。
如果 \(l = r\) 且左右两边至少有一个小于 \(a[l]\) 的元素,则有 \(\phi\) 和 \(a[l]\) 两种,否则只有 \(a[l]\) 一种。
code
其中 \(f[i][j]\) 存的是 \([i, i + (1 << j) - 1]\) 内最小元素的位置。
\(L\_less\) 表示左边是否存在比区间最小值小的元素,\(R\_less\) 表示右边是否存在比区间最小值小的元素。
void init() {
for(int i = 1; i <= n; ++ i) f[i][0] = i;
for(int j = 1; j < 20; ++ j) {
for(int i = 1; i + (1 << j) - 1 <= n; ++ i) {
if(a[f[i][j - 1]] < a[f[i + (1 << j - 1)][j - 1]]) f[i][j] = f[i][j - 1];
else f[i][j] = f[i + (1 << j - 1)][j - 1];
}
}
}
int get_pos(int l, int r) {
int len = log2l(r - l + 1);
if(a[f[l][len]] < a[f[r - (1 << len) + 1][len]]) return f[l][len];
else return f[r - (1 << len) + 1][len];
}
ll get_val(int l, int r, bool L_less, bool R_less) {
if(l > r) return 1;
if(l == r && (L_less || R_less)) return 2;
if(l == r) return 1;
int p = get_pos(l, r);
ll left = get_val(l, p - 1, L_less, true);
ll right = get_val(p + 1, r, true, R_less);
ll ret = left * right % P;
if(L_less) ret += right;
if(R_less) ret += left;
if(L_less && R_less) -- ret;
return (ret % P + P) % P;
}
void solve() {
cin >> n;
for(int i = 1; i <= n; ++ i) cin >> a[i];
init();
cout << get_val(1, n, 0, 0) << '\n';
}
Educational Codeforces Round 160 (Rated for Div. 2)的更多相关文章
- 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 < ...
- Educational Codeforces Round 48 (Rated for Div. 2) CD题解
Educational Codeforces Round 48 (Rated for Div. 2) C. Vasya And The Mushrooms 题目链接:https://codeforce ...
- Educational Codeforces Round 60 (Rated for Div. 2) 题解
Educational Codeforces Round 60 (Rated for Div. 2) 题目链接:https://codeforces.com/contest/1117 A. Best ...
随机推荐
- 一周内容分享(第 10 期):别让自己"墙"了自己
这里记录过去一周,我看到的值得分享的东西. 一方面是整理记录一下自己一周的学习,另一方面也是期待自己有更多的输出,有更多的价值. 周刊开源(Github:wmyskxz/weekly),欢迎提交 is ...
- SpringBoot RestTemplate 上传文件
@Test public void testUpload() throws Exception { String url = "http://127.0.0.1/file/upload&qu ...
- ATSS : 目标检测的自适应正负anchor选择,很扎实的trick | CVPR 2020
论文指出one-stage anchor-based和center-based anchor-free检测算法间的差异主要来自于正负样本的选择,基于此提出ATSS(Adaptive Training ...
- list集合中的实现类Vector
Vector: 它底层也是用数组来存数据对象的,但它是唯一一个线程安全的,线程安全也就意味着时间长,效率慢,如果是单一线程的话,建议不使用该实现类 add(E element): 将指定的元素追加到此 ...
- AT-abc347(C,D)
AtCoder Beginner Contest 347 C - Ideal Holidays 这场做得最头疼的题 分析 容易想到先用$(d_i+a+b-1)%(a+b)+1$把$d_i$映射到$[1 ...
- 在Keycloak中实现多租户并在ASP.NET Core下进行验证
Keycloak是一个功能强大的开源身份和访问管理系统,提供了一整套解决方案,包括用户认证.单点登录(SSO).身份联合.用户注册.用户管理.角色映射.多因素认证和访问控制等.它广泛应用于企业和云服务 ...
- JDK10的新特性:var和匿名类
目录 简介 匿名类中自定义变量 lambda表达式中的匿名类 总结 简介 匿名类相信大家都用过了,学过JDK8中的lambda表达式之后,可以发现有些匿名类是可以用lambda表达式来替代的,能够被替 ...
- HarmonyOS实践之应用状态变量共享
平时在开发的过程中,我们会在应用中共享数据,在不同的页面间共享信息.虽然常用的共享信息,也可以通过不同页面中组件间信息共享的方式,但有时使用应用级别的状态管理会让开发工作变得简单. 根据不同的使用 ...
- vue截取video视频中的某一帧
在vue中如何做到给视频拍照,留住那一帧的美好呢? 且看代码 <template> <div> <video src="../assets/video.mp4& ...
- 见鬼了!我家的 WiFi 只有下雨天才能正常使用...
这是作者大学时期在家里遇到的一个非常奇怪的网络问题,作者的父亲是一名经验丰富的网络工程师,他们家里使用了一个复杂的网络设置,通过 Wi-Fi 桥接的方式,将父亲公司的高速商业网络连接到家中.但是有一天 ...