快乐的一天从AC开始 | 20210809 | CF1554C
2021/8/10 6:05:51
本文主要是介绍快乐的一天从AC开始 | 20210809 | CF1554C,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目链接
每日吐槽
昨天组长分了个需求,今天再去问组长已经做好了。。。
心路历程
二进制
思路
\(n \oplus x = y \Rightarrow n \oplus x \oplus x \oplus y = y \oplus x \oplus y \Rightarrow n \oplus y = x\)
然后题目是求\(MEX\{ n \oplus x | 0 \le x \le m \}\),那么就有\(MEX = \min\{ x | n \oplus x > m\}\)。
然后就从高位开始贪心,能填0就填0。
完事。
AC代码
#include <bits/stdc++.h> using namespace std; #ifdef BACKLIGHT #include "debug.h" #else #define debug(...) #endif const int N = 1e5 + 5; void solve(int Case) { int n, m; scanf("%d %d", &n, &m); int k = 0; /** * n ^ x = mex * n ^ mex = x * 0 <= x <= m * k = min{x | n ^ x > m} * */ int mask = 0; for (int i = 30; i >= 0; --i) { mask += (1 << i); if (n & (1 << i)) ; else { int ma = (k ^ (n & mask)) + ((1 << i) - 1); if (ma > m) ; else k |= (1 << i); debug(k, ma, k ^ n, m); } } printf("%d\n", k); } int main() { #ifdef BACKLIGHT freopen("a.in", "r", stdin); #endif int T = 1; scanf("%d", &T); for (int t = 1; t <= T; ++t) solve(t); return 0; }
这篇关于快乐的一天从AC开始 | 20210809 | CF1554C的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-27Nacos多环境配置学习入门
- 2024-12-27Nacos快速入门学习入门
- 2024-12-27Nacos快速入门学习入门
- 2024-12-27Nacos配置中心学习入门指南
- 2024-12-27Nacos配置中心学习入门
- 2024-12-27Nacos做项目隔离学习入门
- 2024-12-27Nacos做项目隔离学习入门
- 2024-12-27Nacos初识学习入门:轻松掌握服务发现与配置管理
- 2024-12-27Nacos初识学习入门:轻松掌握Nacos基础操作
- 2024-12-27Nacos多环境配置学习入门