MOOC算法练习题——特殊的密码锁

```

#include<iostream>

#include<cstdio>

#include<cstring>

#include<algorithm>

#include<cstdlib>

const int N=3000+20;

using namespace std;

int tot,ans1=0,ans2=0,len;

char a[N],b[N];

int x[N],y[N];

void init(){

    tot=0;

        for(int i=0;i<len;i++)

        {

            x[i]=a[i]-48;

            y[i]=b[i]-48; 

        }

}

int main(){

    scanf("%s",a);

    gets(b);

    scanf("%s",b);

    len=strlen(a);

        init();

        tot++;

        x[0]=x[0]^1;

        x[1]=x[1]^1;

        for(int i=0;i<len-1;i++){

            if(x[i]!=y[i]){

                tot++;

                x[i]^=1;

                x[i+1]^=1;

                x[i+2]^=1;

            }

        }

        if(x[len-1]==y[len-1]) ans1=tot;

        init();

        for(int i=0;i<len-1;i++){

            if(x[i]!=y[i]){

                tot++;

                x[i]^=1;

                x[i+1]^=1;

                x[i+2]^=1;

            }

        }

        if(x[len-1]==y[len-1]) ans2=tot;

    if(!ans1&&!ans2) printf("impossible");

    else if(!ans1||!ans2) printf("%d",max(ans1,ans2));

    else printf("%d",min(ans1,ans2));

    return 0;

}

```

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容