蓝桥杯官网练习题(翻硬币)

题目描述

小明正在玩一个"翻硬币"的游戏。

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

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

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

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

我们约定:把翻动相邻的两个硬币叫做一步操作。

输入描述

两行等长的字符串,分别表示初始状态和要达到的目标状态。

每行的长度<1000。

输出描述

一个整数,表示最小操作步数。

输入输出样例

示例

输入

复制代码
**********
o****o****

输出

复制代码
5

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 64M
java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int ans=0;
        String str=scan.next();
        String str1=scan.next();
        char[] ch=str.toCharArray();
        char[] ch1=str1.toCharArray();
        for(int i=0;i<ch.length-1;i++){
          if(ch[i]!=ch1[i]){
            ch[i]=ch[i]=='*'?'o':'*';
            ch[i+1]=ch[i+1]=='*'?'o':'*';
            ans++;
          }
        }
        System.out.println(ans);
        scan.close();
    }
}
相关推荐
mmz120728 分钟前
双指针问题5(c++)
c++·算法
星空露珠29 分钟前
lua获取随机颜色rgb转换hex
数据结构·数据库·算法·游戏·lua
mit6.82434 分钟前
预hash|vector<int> dfs
算法
Zsy_05100336 分钟前
【数据结构】堆简单介绍、C语言实现堆和堆排序
c语言·数据结构·算法
Rock_yzh36 分钟前
LeetCode算法刷题——56. 合并区间
数据结构·c++·学习·算法·leetcode·职场和发展·动态规划
普贤莲花39 分钟前
小米面试总结20251202
面试·职场和发展
sheeta199841 分钟前
LeetCode 每日一题笔记 日期:2025.12.02 题目:3623. 统计梯形的数目 I
笔记·算法·leetcode
宇来风满楼41 分钟前
U-KAN复现
人工智能·深度学习·神经网络·算法·机器学习
W_chuanqi1 小时前
单目标实数参数优化:算法jSO
算法