【BestCoder Round 65A】【水题】ZYB's Biology DNA与RNA是否匹配

ZYB's Biology

 
 Accepts: 848
 
 Submissions: 1199
 Time Limit: 2000/1000 MS (Java/Others)
 
 Memory Limit: 131072/131072 K (Java/Others)
问题描述
$ZYB(ZJ-267)$在$NOIP$拿到$600$分之后开始虐生物题,他现在扔给你一道简单的生物题:给出一个$DNA$序列和一个$RNA$序列,
问它们是否配对。

$DNA$序列是仅由$A,C,G,T$组成的字符串,$RNA$序列是仅由$A,C,G,U$组成的字符串。

$DNA$和$RNA$匹配当且仅当每个位置上$A$与$U$,$T$与$A$,$C$与$G$,$G$与$C$匹配。
输入描述
第一行一个整数$T$表示数据组数。

对于每组数据:

第一行一个整数$N$表示$DNA$和$RNA$序列的长度.

第二行一个长度为$N$的字符串$A$表示$DNA$序列.

第三行一个长度为$N$的字符串$B$表示$RNA$序列.

$1 \leq T \leq 10$,$1 \leq N \leq 100$
输出描述
对于每组数据,输出一行$YES$或$NO$,表示是否匹配.
输入样例
2
4
ACGT
UGCA
4
ACGT
ACGU
输出样例
YES
NO
#include<stdio.h>
#include<iostream>
#include<string.h>
#include<string>
#include<ctype.h>
#include<math.h>
#include<set>
#include<map>
#include<vector>
#include<queue>
#include<bitset>
#include<algorithm>
#include<time.h>
using namespace std;
void fre(){freopen("c://test//input.in","r",stdin);freopen("c://test//output.out","w",stdout);}
#define MS(x,y) memset(x,y,sizeof(x))
#define MC(x,y) memcpy(x,y,sizeof(x))
#define MP(x,y) make_pair(x,y)
#define ls o<<1
#define rs o<<1|1
typedef long long LL;
typedef unsigned long long UL;
typedef unsigned int UI;
template <class T1,class T2>inline void gmax(T1 &a,T2 b){if(b>a)a=b;}
template <class T1,class T2>inline void gmin(T1 &a,T2 b){if(b<a)a=b;}
const int N=0,M=0,Z=1e9+7,ms63=1061109567;
int casenum,casei;
char a[105],b[105];
int n;
bool check()
{
	for(int i=0;i<n;++i)
	{
		if(a[i]=='A')
		{
			if(b[i]!='U')return 0;
		}
		else if(a[i]=='T')
		{
			if(b[i]!='A')return 0;
		}
		else if(a[i]=='C')
		{
			if(b[i]!='G')return 0;
		}
		else if(a[i]=='G')
		{
			if(b[i]!='C')return 0;
		}
	}
	return 1;
}
int main()
{
	scanf("%d",&casenum);
	for(casei=1;casei<=casenum;++casei)
	{
		scanf("%d",&n);
		scanf("%s%s",a,b);
		puts(check()?"YES":"NO");
	}
	return 0;
}
/*
【trick&&吐槽】
对于一个大小为100的char[],空间开100是不会有问题的噗~

【题意】
给你一个DNA和一个RNA,让你判断它们是否恰好匹配

【类型】
水题

【分析】
C语言级别的模拟

*/


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值