第十四届蓝桥杯省赛PythonA/C组------翻转

题目描述:

小蓝用黑白棋的n个棋子排成了一行,他在脑海里想象出了一个长度为n的01串T,他发现如果把黑棋当做1,白棋当做0,这一行棋子也是一个长度为n 的01串S。

小蓝决定,如果在S中发现一个棋子和它两边的棋子都不一样,就可以将其翻转变成另一个颜色。也就是说,如果S中存在子串101或者010,就可以选择将其分别变为111和000,这样的操作可以无限重复。

小蓝想知道最少翻转多少次可以把S变成和T一模一样。


输入格式:

输入包含多组数据。

输入的第一行包含一个正整数D表示数据组数。

后面 2D 行每行包含一个01串,每两行为一组数据,第2*i-1行为第i组数据的T,第 2*i行为第i组数据的 Si,S¡和T 长度均为ni

输出格式:

对于每组数据,输出一行包含一个整数,表示答案,如果答案不存在请输出 -1。


大体思路 :

1、这个题关键就是读懂题找到谁是T谁是S

2、还有以谁为基准的对应关系即可解题


AC代码如下:

cpp 复制代码
#include<iostream>
#include<cstring>
#include<algorithm>

using namespace std;

int main()
{
    int n;
    cin >> n;
    n = n*2;
    string s[n];
    for(int i=0;i<n;i++) cin >> s[i];
    //这里的i+=2很巧妙,可以手算模拟一下
    for (int i = 1; i < n; i +=2 )
    {
        int k = 0;
        int cnt = 0;//计算改变次数
        bool is_same = true;
        while(k<s[i].size())
        {
            //我们可以发现 一个规律就是如果前面两个数不一样
            //那一定是不行的
            if(s[i][0] != s[i-1][0])
            {
                is_same = false;
                break;
            }
            else
            {
                k++;
                //跟前后去做比较
                if(s[i][k] != s[i-1][k])
                {
                    if(s[i][k] != s[i][k-1] && s[i][k] != s[i][k+1] && s[i][k-1] == s[i][k+1])
                    {
                        if(s[i][k] == '0')
                        {
                            s[i][k] = '1';
                            cnt++;
                        }
                        else
                        {
                            s[i][k] = '0';
                            cnt++;
                        }
                    }
                }
            }
        }
        if(s[i] != s[i-1])  is_same = false;
        if(is_same) cout << cnt << endl;
        else cout << "-1" << endl;
    }
    return 0;
}
相关推荐
AI成长日志3 分钟前
【算法学习专栏】动态规划基础·中等两题精讲(198.打家劫舍、322.零钱兑换)
学习·算法·动态规划
计算机安禾6 分钟前
【数据结构与算法】第28篇:平衡二叉树(AVL树)
开发语言·数据结构·数据库·线性代数·算法·矩阵·visual studio
测试_AI_一辰6 分钟前
AI 如何参与 Playwright 自动化维护:一次自动修复闭环实践
人工智能·算法·ai·自动化·ai编程
未来之窗软件服务19 分钟前
算法设计—计算机等级考试—软件设计师考前备忘录—东方仙盟
算法·软件设计师·计算机等级考试
未来之窗软件服务22 分钟前
哈夫曼树构造—计算机等级考试—软件设计师考前备忘录—东方仙盟
算法·软件设计师·计算机等级考试·仙盟创梦ide·东方仙盟
kpl_2043 分钟前
智能指针(C++)
c++·c++11·智能指针
爱编码的小八嘎1 小时前
C语言完美演绎6-21
c语言
SUNNY_SHUN1 小时前
VLM走进农田:AgriChat覆盖3000+作物品类,607K农业视觉问答基准开源
论文阅读·人工智能·算法·开源
黎阳之光1 小时前
视频孪生赋能车路云一体化,领跑智慧高速新征程
人工智能·算法·安全·数字孪生
Darkwanderor1 小时前
高精度计算——基础模板整理
c++·算法·高精度计算