2020牛客国庆集训派对day1 H

Ponk Warshall

https://ac.nowcoder.com/acm/contest/7817/H

分析

我们可以分类讨论。

  • 首先如果 这显然不需要进行操作。
  • 如果 , 我们可以进行一次操作将两个配对,可以证明这个操作是最优的。
  • 同理我们可以两次操作配对。
  • 那么最后剩下的就是四个一组的。根据鸽巢原理我们一定可以在 次操作之内配对。

那么我们现在只需要记录这四种情况有多少个,然后由前到后考虑就可以了,总的复杂度为

代码

#include<bits/stdc++.h>
using namespace std;
const int N = 1e6 + 1000;
char A[N],B[N];
int get(char ch) {if(ch=='A')return 1;if(ch=='G')return 2;if(ch=='C')return 3;if(ch=='T')return 0;}
int c[4][4],n,ans;
int main() {
    scanf("%s%s",A+1,B+1);n = strlen(A+1);for(int i = 1;i <= n;i++) {
        if(get(A[i])==get(B[i])) continue;c[get(A[i])][get(B[i])]++;
    }
    for(int i = 0;i < 4;i++) for(int j = 0;j < 4;j++) {
        int Min = min(c[i][j],c[j][i]);c[i][j]-=Min;c[j][i]-=Min;ans+=Min;
    }
    for(int i = 0;i < 4;i++) for(int j = 0;j < 4;j++) for(int k = 0;k < 4;k++) {
        int Min = min(min(c[i][j],c[j][k]),c[k][i]);c[i][j]-=Min;c[j][k]-=Min;c[k][i]-=Min;ans+=Min*2;
    }
    for(int i = 0;i < 4;i++) ans += c[i][3] * 3;
    cout << ans << endl;return 0;
}
比赛题解 文章被收录于专栏

近期比赛的题解应该有吧。。。

全部评论

相关推荐

评论
7
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
9757次浏览 91人参与
# 你的实习产出是真实的还是包装的? #
1758次浏览 40人参与
# 巨人网络春招 #
11304次浏览 223人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7480次浏览 43人参与
# 简历第一个项目做什么 #
31574次浏览 331人参与
# 重来一次,我还会选择这个专业吗 #
433386次浏览 3926人参与
# MiniMax求职进展汇总 #
23869次浏览 308人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187010次浏览 1122人参与
# 牛客AI文生图 #
21410次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152302次浏览 887人参与
# 研究所笔面经互助 #
118874次浏览 577人参与
# 简历中的项目经历要怎么写? #
310086次浏览 4195人参与
# AI时代,哪些岗位最容易被淘汰 #
63454次浏览 805人参与
# 面试紧张时你会有什么表现? #
30490次浏览 188人参与
# 你今年的平均薪资是多少? #
213021次浏览 1039人参与
# 你怎么看待AI面试 #
179885次浏览 1235人参与
# 高学历就一定能找到好工作吗? #
64316次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76442次浏览 374人参与
# 我的求职精神状态 #
447997次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363264次浏览 2637人参与
# 腾讯音乐求职进展汇总 #
160590次浏览 1111人参与
# 校招笔试 #
470514次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务