今天再刷蓝桥的题目时,发现这道题目的第二种更为简洁的做法;
首先题目描述如下:
样例输入
5
ACGTG
ACGTC
样例输出
2
对于这道题目,我们想的是用两个数组将其分别存储下来,然后再根据A-T、G-C的配对关系将数组二(即序列二)进行对应的修改,那么我们除了使用map的办法以外,还能否使用其他的数学关系来表示其配对关系呢?
这里我想到了使用不同的两组数字其各自之和分别等于同一个数的对应方法:我们将A看作1;T看作4;C看作2;G看作3;如此一来,我们能够形成配对关系的数字之和就固定为5了,这样可以大幅的简化我们进行配对判断的过程
AC代码
AC代码如下:
#include <iostream>
using namespace std;
const int N = 1e3+5;
int map1[N],map2[N];
int main()
{
int n;cin >> n;
char x;
for(int i = 1; i <= n; ++i)
{
cin >> x;
switch(x)
{
case 'A':map1[i] = 1;break;
case 'T':map1[i] = 4;break;
case 'C':map1[i] = 2;break;
case 'G':map1[i] = 3;
}
}
for(int i = 1; i <= n; ++i)
{
cin >> x;
switch(x)
{
case 'A':map2[i] = 1;break;
case 'T':map2[i] = 4;break;
case 'C':map2[i] = 2;break;
case 'G':map2[i] = 3;
}
}
int cnt = 0;
for(int i = 1;i <= n; ++i)
{
int flag = 1;
if(map1[i] + map2[i] == 5)continue;
for(int j = i + 1; j <= n; ++j)
{
if(map1[i] + map2[j] == 5 && map1[j] + map2[i] == 5)
{
swap(map2[i],map2[j]);
cnt ++;
flag = 0;
break;
}
}
if(flag){
map2[i] = 5 - map1[i];
cnt ++;
}
}
cout << cnt;
return 0;
}