贪心算法-翻硬币
admin
2024-02-02 00:54:22

问题描述
小明正在玩一个“翻硬币”的游戏。

桌上放着排成一排的若干硬币。我们用 * 表示正面,用 o 表示反面(是小写字母,不是零)。

比如,可能情形是:**oo***oooo

如果同时翻转左边的两个硬币,则变为:oooo***oooo

现在小明的问题是:如果已知了初始状态和要达到的目标状态,每次只能同时翻转相邻的两个硬币,那么对特定的局面,最少要翻动多少次呢?

我们约定:把翻动相邻的两个硬币叫做一步操作,那么要求:

输入格式
两行等长的字符串,分别表示初始状态和要达到的目标状态。每行的长度<1000

输出格式
一个整数,表示最小操作步数。

样例输入1


o****o****
样例输出1
5
样例输入2
o**o***o**
o***o**o**
样例输出2
1

思路

贪心题。   我的思路是先对两个字符串进行比较,用数组记录下比较的结果,0表示字符相同,1表示字符不同。   用题目给的例子示范:

  比较结果为:

  1000010000

  翻动次数就是两个1之间的下标之差。   当然也有些复杂的情况,若比较结果为:

  101101100101

  你是直接翻动中间的两个“11”处的硬币再解决其它硬币呢(因为翻动相邻的两个硬币只算一次操作),还是按上面的规则依次计算呢?

  这道题“贪心”之处就在这里,事实上从左到右依次按上面蓝字的规则累加计数,就可求得最优结果。

代码:

import java.util.Scanner;public class FlipCoin {public static void main(String[] args) {Scanner input = new Scanner(System.in);String str1 = input.next();String str2 = input.next();char[] arr1 = str1.toCharArray();char[] arr2 = str2.toCharArray();int count = 0;for (int i = 0; i < arr2.length -1; i++) {if (arr1[i] != arr2[i]) {arr1[i] = arr2[i];if (arr1[i+1] =='*') {arr1[i+1] ='o';}else {arr1[i+1] ='*';}count++;}}System.out.println(count);}
}

相关内容

热门资讯

AI看非遗里的福州|三条簪 AI辅助生成福州传统梳妆技艺“三条簪”又名“三把刀”,是旧时福州女子的传统妆束,代表着勇敢、勤劳、刚...
最新或2023(历届)上海交通... 上海交通大学最新或2023(历届)保送生招生简章  为贯彻《国务院关于深化考试招生制度改革的实施意...
最新或2023(历届)河海大学... 河海大学最新或2023(历届)保送生选拔预告 河海大学最新或2023(历届)继续面向全国招收保送生。...
最新或2023(历届)浙江三位... 最新或2023(历届)浙江三位一体招生要求和报名条件为贯彻国家和省中长期教育改革和发展规划纲要精神,...
最新或2023(历届)浙江三位... 据省教育厅昨天统计,今年共有52所院校参与招生试点,比去年增加15所。除浙江大学、上海交通大学、中国...