快乐的一天从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-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享