蓝桥杯 DNA序列修正

今天再刷蓝桥的题目时,发现这道题目的第二种更为简洁的做法;

首先题目描述如下:

样例输入

复制代码
5
ACGTG
ACGTC

样例输出

复制代码
2

对于这道题目,我们想的是用两个数组将其分别存储下来,然后再根据A-T、G-C的配对关系将数组二(即序列二)进行对应的修改,那么我们除了使用map的办法以外,还能否使用其他的数学关系来表示其配对关系呢?

这里我想到了使用不同的两组数字其各自之和分别等于同一个数的对应方法:我们将A看作1;T看作4;C看作2;G看作3;如此一来,我们能够形成配对关系的数字之和就固定为5了,这样可以大幅的简化我们进行配对判断的过程

AC代码

AC代码如下:

cpp 复制代码
#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;
}
相关推荐
无敌最俊朗@5 小时前
力扣hot100-206反转链表
算法·leetcode·链表
Kuo-Teng5 小时前
LeetCode 279: Perfect Squares
java·数据结构·算法·leetcode·职场和发展
王哈哈^_^5 小时前
YOLO11实例分割训练任务——从构建数据集到训练的完整教程
人工智能·深度学习·算法·yolo·目标检测·机器学习·计算机视觉
檐下翻书1736 小时前
从入门到精通:流程图制作学习路径规划
论文阅读·人工智能·学习·算法·流程图·论文笔记
CoderYanger6 小时前
B.双指针——3194. 最小元素和最大元素的最小平均值
java·开发语言·数据结构·算法·leetcode·职场和发展·1024程序员节
小曹要微笑7 小时前
STM32各系列时钟树详解
c语言·stm32·单片机·嵌入式硬件·算法
前进的李工8 小时前
LeetCode hot100:094 二叉树的中序遍历:从递归到迭代的完整指南
python·算法·leetcode·链表·二叉树
麦麦大数据9 小时前
F049 知识图谱双算法推荐在线学习系统vue+flask+neo4j之BS架构开题论文全源码
学习·算法·知识图谱·推荐算法·开题报告·学习系统·计算机毕业设计展示
兩尛9 小时前
215. 数组中的第K个最大元素
数据结构·算法·排序算法
952369 小时前
数据结构-堆
java·数据结构·学习·算法