【巧妙】【3-21个人赛】Problem C 01串

2023-05-03,

Problem C

Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 65535/32768K (Java/Other)
Total Submission(s) : 167   Accepted Submission(s) : 29

Font: Times New Roman | Verdana | Georgia

Font Size: ← →

Problem Description

调皮的萌萌喜欢在传输的数据上做改动,具体方法如下:

在一串由0、1组成的数据中,执行任意次数(可能为0次)的如下的操作:

任意选取相邻的两位a、b,把这两位变成a or b、a xor b。

比如:10可变为11,11可变为01或10.

给你两个01串s1、s2,请你s2是否有可能是萌萌用s1改动的来的数据。

Input

输入数据包含多组测试数据。

每组数据包含两行0、1组成的字符串s1、s2。

Output

对于每组数据,如果s2可由s1改动而来,输出“YES”,否则输出“NO”。

Sample Input

11
10
1
01
000
101

Sample Output

YES
NO
NO

SB了 很容易发现一个规律 01 11 10 可以互相转换
所以一个串只要里面有个1  都可以变成00000000000000000001
所以 只需要判断一下 2个串 
 是否都有1和长度相等即可

代码如下:

#include <stdio.h>
#include <ctype.h>
#include <string.h>
#include <stdlib.h>
#include <limits.h>
#include <math.h>
#include <algorithm>
using namespace std; char stra[100005],strb[100005]; int main()
{
// freopen("a.in","r",stdin);
//freopen("b.out","w",stdout);
while(~scanf("%s%s",stra,strb)){
int lena=strlen(stra),lenb=strlen(strb);
if(lena!=lenb){
puts("NO");
continue;
}
int acnt=0,bcnt=0;
for(int i=0;i<lena;i++){
if(stra[i]=='1')acnt++;
if(strb[i]=='1')bcnt++;
}
if(acnt==0&&bcnt==0){
puts("YES");
}else if(acnt&&bcnt){
puts("YES");
}else{
puts("NO");
}
}
return 0;
}

巧妙】【3-21个人赛】Problem C 01串的相关教程结束。

《【巧妙】【3-21个人赛】Problem C 01串.doc》

下载本文的Word格式文档,以方便收藏与打印。