第十四届蓝桥杯省赛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代码如下: 

#include
#include
#include

using namespace std;

int main()
{
    int n;
    cin >> n;
    n = n*2;
    string s[n];
    for(int i=0;i> s[i];
    //这里的i+=2很巧妙,可以手算模拟一下
    for (int i = 1; i < n; i +=2 )
    {
        int k = 0;
        int cnt = 0;//计算改变次数
        bool is_same = true;
        while(k

你可能感兴趣的:(题解,蓝桥杯,c语言,算法,c++)