Codeforces Round #833 (Div. 2)补题
Codeforces Round #833 (Div. 2)
D. ConstructOR
知识点:高位和对低位无影响
一开始以为和广州的M一样,是数位dp,后来发现只要找到一个就行
果然无论什么时候都要看清题目
这时候还是没有什么思路,然后就看了题解的提示:当a和b有奇数时,d为偶数一定不可以
那显然这个结论可以继续推广,比较a,b,d的二进制后导0的大小即可
当a,b,d都截去d的后导0时,此时d为奇数
那么我们可以再次应用高位计算不会对低位产生影响这个条件
直接观察 \(a|b\) 如果当前第 \(i\) 位的 \(ans\) 与 \(a|b\) 不同时,
在这一位上加上 \(d<<i\) 即可对 \(ans\) 的第 \(i\) 位取反
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define rep(i,l,r) for(int i=l;i<=r;i++)
ll a, b, d;
void solve()
{
cin >> a >> b >> d;
int w = __builtin_ctz(d);
if ((a & ((1 << w) - 1)) || (b & ((1 << w) - 1)))
{
cout << -1 << endl;
return;
}
a |= b;
a >>= w;
d >>= w;
ll ans(0);
for (int i = 0; (1ll << i) <= a; i++)
if ((ans ^ a) & (1 << i)) ans += d << i;
cout << (ans << w) << endl;
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
int T = 1;
cin >> T;
rep(i, 1, T) solve();
}
E. Yet Another Array Counting Problem
知识点:笛卡尔树上dp
看的大佬的题解,已经说的很清楚了,我就不献丑了
属实没想到能把题面这么转化,涨见识了
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define fi first
#define se second
#define pii pair<int,int>
#define rep(i,l,r) for(int i=l;i<=r;i++)
#define per(i,r,l) for(int i=r;i>=l;i--)
template<class T> using vc = vector<T>;
const ll mod = 1e9 + 7;
void solve()
{
int n, m;
cin >> n >> m;
vc<array<int, 2>> h(n + 1);
rep(i, 1, n) h[i][0] = h[i][1] = -1;
vc<int> a(n + 1);
rep(i, 1, n) cin >> a[i];
int sz = (int)log2(1.0 * n);
vc<vc<pii>> f(n + 1, vc<pii>(sz + 1));
rep(i, 1, n) f[i][0] = {a[i], i};
rep(j, 1, sz) for (int i = 1; i + (1 << j) - 1 <= n; i++)
{
pii a = f[i][j - 1];
pii b = f[i + (1 << (j - 1))][j - 1];
if (a.fi >= b.fi) f[i][j] = a;
else f[i][j] = b;
}
auto RMQ = [&](int l, int r)
{
int k = (int)log2(1.0 * r - l + 1);
pii a = f[l][k];
pii b = f[r - (1 << k) + 1][k];
if (a.fi >= b.fi) return a.se;
return b.se;
};
int rt = RMQ(1, n);
function<void(int, int, int)> build = [&](int rt, int l, int r)
{
if (l < rt)
{
int ls = RMQ(l, rt - 1);
h[rt][0] = ls;
build(ls, l, rt - 1);
}
if (r > rt)
{
int rs = RMQ(rt + 1, r);
h[rt][1] = rs;
build(rs, rt + 1, r);
}
};
build(rt, 1, n);
vc<vc<ll>> dp(n + 1, vc<ll>(m + 1));
function<void(int)> dfs = [&](int rt)
{
int ls = h[rt][0], rs = h[rt][1];
if (ls == -1 && rs == -1) rep(i, 1, m) dp[rt][i] = 1;
else if (rs == -1)
{
dfs(ls);
rep(i, 1, m - 1)
dp[rt][i + 1] = (dp[ls][i] + dp[rt][i]) % mod;
}
else if (ls == -1)
{
dfs(rs);
rep(i, 1, m)
dp[rt][i] = (dp[rs][i] + dp[rt][i - 1]) % mod;
}
else
{
dfs(ls), dfs(rs);
rep(i, 1, m)
{
dp[ls][i] = (dp[ls][i] + dp[ls][i - 1]) % mod;
dp[rs][i] = (dp[rs][i] + dp[rs][i - 1]) % mod;
}
rep(i, 1, m)
{
dp[rt][i] = (dp[rt][i - 1] + (dp[rs][i] - dp[rs][i - 1]) * dp[ls][i - 1]) % mod;
dp[rt][i] = (dp[rt][i] + dp[rs][i - 1] * (dp[ls][i - 1] - (i > 1 ? dp[ls][i - 2] : 0))) % mod;
}
}
};
dfs(rt);
ll ans(0);
rep(i, 1, m) ans = (ans + dp[rt][i]) % mod;
if (ans < 0) ans += mod;
cout << ans << endl;
}
int main()
{
ios::sync_with_stdio(0), cin.tie(0);
int T; cin >> T;
rep(i, 1, T) solve();
return 0;
}
Codeforces Round #833 (Div. 2)补题的更多相关文章
- Codeforces Round #412 Div. 2 补题 D. Dynamic Problem Scoring
D. Dynamic Problem Scoring time limit per test 2 seconds memory limit per test 256 megabytes input s ...
- Codeforces Round #585 (Div. 2) [补题]
前言 2019.9.16 昨天下午就看了看D题,没有写对,因为要补作业,快点下机了,这周争取把题补完. 2019.9.17 这篇文章或者其他文章难免有错别字不被察觉,请读者还是要根据意思来读,不要纠结 ...
- Codeforces Round #786 (Div. 3) 补题记录
小结: A,B,F 切,C 没写 1ll 对照样例才发现,E,G 对照样例过,D 对照样例+看了其他人代码(主要急于看后面的题,能调出来的但偷懒了. CF1674A Number Transforma ...
- Codeforces Round #429 (Div. 2) 补题
A. Generous Kefa 题意:n个气球分给k个人,问每个人能否拿到的气球都不一样 解法:显然当某种气球的个数大于K的话,就GG了. #include <bits/stdc++.h> ...
- Codeforces Round #419 (Div. 1) 补题 CF 815 A-E
A-C传送门 D Karen and Cards 技巧性很强的一道二分优化题 题意很简单 给定n个三元组,和三个维度的上限,问存在多少三元组,使得对于给定的n个三元组中的每一个,必有两个维度严格小于. ...
- Codeforces Round #590 (Div. 3)补题
要想上2000分,先刷几百道2000+的题再说 ---某神 题目 E F 赛时是否尝试 × × tag math bitmask 难度 2000 2400 状态 ∅ √ 解 E 待定 F 传送门 第一 ...
- Codeforces Round #574 (Div. 2)补题
A. Drinks Choosing 统计每种酒有多少人偏爱他们. ki 为每种酒的偏爱人数. 输出ans = (n + 1)/2 > Σki / 2 ? (n + 1)/2 - Σki / ...
- Codeforces Round #615 (Div. 3) 补题记录
第一次搞CF,结果惨不忍睹...还是太菜了 A:要用到全部的钱,所以总数必须是3的倍数,而且初始状态下任意一人的钱数不能超过总数除以3,否则没法分了 (也就这个签到算是在我能力范围之内了....) # ...
- Codeforces Round #617 (Div. 3) 补题记录
1296A - Array with Odd Sum 题意:可以改变数组中的一个数的值成另外一个数组中的数,问能不能使数组的和是个奇数 思路:签到,如果本来数组的和就是个奇数,那就OK 如果不是,就需 ...
随机推荐
- K8S Pod及其控制器
Pod K8S里能够运行的最小逻辑单元,1个Pod可以运行多个容器 Pod 控制器 Pod控制器是Pod启动的一种模版,用来保证在K8S中启动的Pod始终按照人们的预期运行(副本数,生命周期.健康状态 ...
- 【Android 逆向】switch 的smail特征
JAVA 源码 ... String str1 = packedSwitch(1); ... private String packedSwitch(int i) { String str = nul ...
- Beats:通过Metricbeat实现外部对Elastic Stack的监控
- FastDFS与nginx配置使用的配置信息
# 获取图片 location /group[1-9]/M0[0-9] { root /home/vdc1/fastdfs_storage/data; ngx_fastdfs_module; } # ...
- 使用 kubectl 执行 Rolling Update(滚动更新)
Rolling Update滚动更新 通过使用新版本的 Pod 逐步替代旧版本的 Pod 来实现 Deployment 的更新,从而实现零停机.新的 Pod 将在具有可用资源的 Node(节点)上进行 ...
- 2. Fluentd事件的生命周期
事件(Event)是Fluentd内部处理流程使用的数据结构,日志记录一旦进入Fluentd便被封装成一个event.Event由三部分组成:tag.time.record. tag: 标识事件的来源 ...
- 推送本地镜像到Dokcer Hub仓库
# 登陆 [root@docker ~]# docker login # 注意:后面不输入网址 Login with your Docker ID to push and pull images fr ...
- 实用脚本:检查高 CPU / 内存消耗进程
1 检查高 CPU 消耗进程在 Linux 上运行了多长时间的 Bash 脚本 该脚本将帮助你确定高 CPU 消耗进程在 Linux 上运行了多长时间. # vi /opt/scripts/long- ...
- 重学Java泛型
一丶从字节码层面看范型擦除 public class Type1<T> { private T t; } 使用jclasslib插件查看其字节码: 可以看到 t属性的类型是List< ...
- 【Linux】指令学习
Linux学习记录 生命不息,写作不止 一个有梦有戏的人 @怒放吧德德 分享学习心得,欢迎指正,大家一起学习成长! 1.虚拟机网卡配置 服务器重启完成之后,我们可以通过linux的指令 ip addr ...