题面
小明正在玩一个"翻硬币"的游戏。
桌上放着排成一排的若干硬币。我们用 * 表示正面,用 o 表示反面(是小写字母,不是零)。
比如,可能情形是:**oo***oooo;
如果同时翻转左边的两个硬币,则变为:oooo***oooo。
现在小明的问题是:如果已知了初始状态和要达到的目标状态,每次只能同时翻转相邻的两个硬币,那么对特定的局面,最少要翻动多少次呢?
我们约定:把翻动相邻的两个硬币叫做一步操作。
输入描述
两行等长的字符串,分别表示初始状态和要达到的目标状态。
每行的长度<1000。
输出描述
一个整数,表示最小操作步数。
输入样例
**********
o****o****
输出样例
5
题解
贪心
从左往右扫一遍,若与目标不一致,则变换一次。贪心题,一般都靠直觉去蒙!!!
代码
#include<iostream>
#include<string>
using namespace std;
char get(char x) {
return x == 'o' ? '*' : 'o';
}
int main() {
string s, t;
cin >> s >> t;
int res = 0, n = s.length();
for (int i = 0; i < n - 1; i++) {
if (s[i] == t[i]) continue;
s[i] = get(s[i]);
s[i + 1] = get(s[i + 1]);
res++;
}
cout << res << endl;
return 0;
}
标题: | 2013年第四届蓝桥杯省赛-H. 翻硬币 |
---|---|
链接: | https://www.fightingok.cn/detail/163 |
更新: | 2022-09-18 22:44:24 |
版权: | 本文采用 CC BY-NC-SA 3.0 CN 协议进行许可 |