Codeforces Round #721 (Div. 2) AB思维,B2博弈,C题map
补题链接:Here
1527A. And Then There Were K
题目大意:
给一个正整数n,求最大的k,使得 \(n \& (n−1) \& (n−2) \& (n−3) \& … (k) = 0\)
思路:
就假设 \(n\) 为 17,二进制为 10001,我们来模拟一下求解过程。
17 10001
16 10000
15 01111
因为按位与的特点就是,一位上只要有一个0,这一位最后就是0。
我们竖着来看,17到15,每一位上就都出现过一次0了,所以15就是答案。然后举更多例子观察特点,发现,答案就是让n的二进制最左边的1置为0,后面全置为1。
如:
10001 11101 10111的答案都是 01111
【AC代码】
int qpow(int a, int b) {int ans = 1; while (b) {if (b & 1)ans = ans * a; b >>= 1; a = a * a;} return ans;}
void solve() {
int n;
cin >> n;
int ans = 0;
while (n) {
n >>= 1;
++ans;
}
cout << qpow(2, ans - 1) - 1 << "\n";
}
转化思维,模拟上面的过程
void solve() {
ll n, k = 0;
cin >> n;
while (k * 2 + 1 < n)k = k * 2 + 1;
cout << k << "\n";
}
遇到这种位运算的题目,一般都是把数的二进制表示出来,然后根据运算的特点(比如&的特点就是,只要有一个0,最后就是0),找规律。
1527B1. Palindrome Game (easy version)
题目大意:
给一个字符串(这题的字符串一开始一定是一个回文)。
1.可以把一个0变为1,操作者的数字+1。
2.或者翻转整个字符串(前提是该字符串不是回文且上一个人的操作不是翻转)。
Alice先,最后字符串全为1时,谁的数字大谁输,相同则平局。
思路:
因为一开始就是回文,所以Alice只好进行1操作,如果可以在这个操作之后仍然让它时一个回文,那Alice就赢定了。
比如:10001
Alice进行1之后,10101
Bob没法翻转,只好进行1操作,11101
这时,Alice很聪明,不会傻傻地让自己的数字变大,选择2翻转字符串,10111
Bob只好继续1操作,111111
这时Bob都已经数字为2了,Alice为1,所以Alice胜
比如:10101
Alice 1操作之后并不是回文,这就让Bob有机可乘,最后是Bob赢了
关键在于,Alice第一次操作之后它还是不是回文,而这取决于改字符串中间的字符是不是0,只有中间的字符是0,且字符串长为奇数(偶数的话连中间都没有)的时候Alice赢,否则Bob赢。
还有一个特殊情况,就是只有一个0的时候,因为刚开始就是回文,Alice只好1操作,所以Alice必定+1,而Bob是0,所以Bob赢了。
void solve() {
int n; string s;
cin >> n >> s;
int cnt0 = count(s.begin(), s.end(), '0');
if (cnt0 == 1)cout << "BOB\n";//只有一个0
else if (n & 1 and s[n / 2] == '0')cout << "ALICE\n";//是奇数个,中间为0
else cout << "BOB\n";
}
压缩判断条件:奇数个0 并且不为 1 个,此时一定是 Alice 获胜了
void solve() {
int n; string s;
cin >> n >> s;
int k = count(s.begin(), s.end(), '0');
if (k & 1 and k != 1)cout << "ALICE\n";
else cout << "BOB\n";
}
1527B2. Palindrome Game (hard version)
题目大意:
这题跟B1的区别就是,一开始的字符串可能不是回文。
思路:
一开始是回文时,用B1的结论。
一开始不是回文时,Alice就可以一开始就翻转,让Bob喘不过气来,所以Bob不可能赢。
但是有一种平局的情况,001,只有2个0,且中间是0。
void solve() {
int n; string s;
cin >> n >> s;
int k = count(s.begin(), s.end(), '0');
string b = s;
reverse(b.begin(), b.end());
if (b == s) { // 用 1 的结论
if (k == 1 || !(n & 1))cout << "BOB\n";
else if ((n & 1) and s[n / 2] == '0')cout << "ALICE\n";
else cout << "BOB\n";
} else {
if (k == 2 and (n & 1) and s[n / 2] == '0')
cout << "DRAW\n";
else cout << "ALICE\n";
}
}
赛后 DP 写法:很复杂,不推荐
const int N = 1010;
int dp[N][N][2][2];
int vis[N][N][2][2];
int DP(int a, int b, int c, int d) {
if (vis[a][b][c][d])return dp[a][b][c][d];
vis[a][b][c][d] = 1;
int &tmp = dp[a][b][c][d] = N;
if (a + b + c == 0) tmp = 0;
if (b and d) tmp = min(tmp, -DP(a, b, c, 0));
if (a) tmp = min(tmp, -DP(a - 1, b + 1, c, 1) + 1);
if (b) tmp = min(tmp, -DP(a, b - 1, c, 1) + 1);
if (c) tmp = min(tmp, -DP(a, b, c - 1, 1) + 1);
return tmp;
}
void solve() {
int n; string s;
cin >> n >> s;
int a = 0, b = 0, c = 0;
for (int i = 0; i * 2 + 1 < n; ++i) {
if (s[i] == '0' and s[n - i - 1] == '0')a++;
if (s[i] != s[n - 1 - i]) b++;
}
if (n & 1 and s[n / 2] == '0')c = 1;
int ans = DP(a, b, c, 1);
if (ans > 0)cout << "BOB\n";
else if (ans == 0)cout << "DRAW\n";
else cout << "ALICE\n";
}
1527C. Sequence Pair Weight
题目大意:
给一个数组,求每个子序列的一对相同数字的数量之和。
分析:
暴力 \(\mathcal{O}(n^2)\),肯定不行,所以肯定有什么 \(\mathcal{O}(n)\) 的方法可以实现。
首先,答案肯定跟这些数字出现的次数有关,其次,也跟数字所在的位置有关。
所以很容易想到用 map 去存储位置并计数
void solve() {
map<int, ll>mp;
ll ans = 0;
int n;
cin >> n;
for (int i = 1, a; i <= n; ++i) {
cin >> a;
ans += mp[a] * (n - i + 1);
mp[a] += i;
}
cout << ans << "\n";
}
Codeforces Round #721 (Div. 2) AB思维,B2博弈,C题map的更多相关文章
- Codeforces Round #721 (Div. 2)A. And Then There Were K(位运算,二进制) B1. Palindrome Game (easy version)(博弈论)
半个月没看cf 手生了很多(手动大哭) Problem - A - Codeforces 题意 给定数字n, 求出最大数字k, 使得 n & (n−1) & (n−2) & ...
- Codeforces Round #713 (Div. 3)AB题
Codeforces Round #713 (Div. 3) Editorial 记录一下自己写的前二题本人比较菜 A. Spy Detected! You are given an array a ...
- Codeforces Round #298 (Div. 2) A、B、C题
题目链接:Codeforces Round #298 (Div. 2) A. Exam An exam for n students will take place in a long and nar ...
- Codeforces Round #297 (Div. 2)A. Vitaliy and Pie 水题
Codeforces Round #297 (Div. 2)A. Vitaliy and Pie Time Limit: 2 Sec Memory Limit: 256 MBSubmit: xxx ...
- 【CF1256】Codeforces Round #598 (Div. 3) 【思维+贪心+DP】
https://codeforces.com/contest/1256 A:Payment Without Change[思维] 题意:给你a个价值n的物品和b个价值1的物品,问是否存在取物方案使得价 ...
- Codeforces Round #260 (Div. 2)AB
http://codeforces.com/contest/456/problem/A A. Laptops time limit per test 1 second memory limit per ...
- Codeforces Round #259 (Div. 2)AB
链接:http://codeforces.com/contest/454/problem/A A. Little Pony and Crystal Mine time limit per test 1 ...
- Codeforces Round #143 (Div. 2) (ABCD 思维场)
题目连链接:http://codeforces.com/contest/231 A. Team time limit per test:2 seconds memory limit per test: ...
- Codeforces Round #395 (Div. 2)(A.思维,B,水)
A. Taymyr is calling you time limit per test:1 second memory limit per test:256 megabytes input:stan ...
- Codeforces Round #416 (Div. 2)(A,思维题,暴力,B,思维题,暴力)
A. Vladik and Courtesy time limit per test:2 seconds memory limit per test:256 megabytes input:stand ...
随机推荐
- JAVA学习week2
这周:根据老师在群里面推荐的JAV学习路线,初步规划了一下学习方案 并找到了相关的视频,目前来说在学习SE.学习内容:环境变量的配置和简单的hello world程序书写的注意点 下周:打算进行简单的 ...
- [USACO2007FEBS] Cow Party S
题目描述 寒假到了,\(n\) 头牛都要去参加一场在编号为 \(x\) 的牛的农场举行的派对,农场之间有 \(m\) 条有向路,每条路都有一定的长度. 每头牛参加完派对后都必须回家,无论是去参加派对还 ...
- 剑指Offer43:1~n整数中1出现的次数(数位DP)
解题思路:数位DP.dp数组为dp[pos][sum]表示当前位以下还有pos个可变位并且当前位以及它的最高位出现了sum个1的dp值.因为数的取值为2^31所以,数组开dp[10][10]就够了. ...
- MongoDB副本集的搭建和管理(高可用)
使得mongodb具备自动故障转移.高可用.读写分离. 副本集默认情况下读写都只是通过主库,副节点只是备份数据而已,但是可以设置副节点允许读操作,这样就可以做成读写分离. 使用pymongo的时候也可 ...
- 文心一言 VS 讯飞星火 VS chatgpt (166)-- 算法导论13.1 6题
六.用go语言,在一棵黑高为 k 的红黑树中,内部结点最多可能有多少个?最少可能有多少个? 文心一言: 红黑树是一种自平衡的二叉查找树,其中每个节点都有一个颜色属性,可以是红色或黑色.红黑树满足以下性 ...
- java,类、实例化、构造方法、this关键字、方法重载
编写类的步骤: 1.定义类名 2.编写类的属性 3.编写类的方法 public 访问修饰符,表示在整个项目中都可以调用,也可以用其他词 使用class关键字来定义类,如下,定义一个Cat类 给了属性 ...
- 三个月我迁移了100PB数据
2023年马上结束,这一年做了不少事情,有一项我可以吹好几年,忍不住和大家分享一下啊. 需求 去年底收到一项需求,要求2个月内从某云存储迁移100PB数据到微软云存储,包含几百亿个文件.当时听到这个数 ...
- GPT-4多模态大型语言模型发布
GPT-4 模型是OpenAI开发的第四代大型语言模型(LLM),它将是一个多模态模型,会提供完全不同的可能性-例如文字转图像.音乐甚至视频.GPT 全称为 Generative Pre-traine ...
- Kiractf
信息收集 主机发现和端口扫描只开放了80的web服务 WEB打点 访问首页有文件上传,肯定可以利用一波.language那个页面甚至文件包含都写脸上了. root@Lockly tmp/ki ...
- 标注工具合集(点云&图片)
有什么问题欢迎留言交流,发现好用的会持续更新-- 图片类 1. labelimg:https://github.com/tzutalin/labelImg --- 只能拉框 2. labelme:ht ...