环状 DNA 序列的最小表示法

问题描述

小C正在研究一种环状的 DNA 结构,它由四种碱基ACGT构成。这种环状结构的特点是可以从任何位置开始读取序列,因此一个长度为 n 的碱基序列可以有 n 种不同的表示方式。小C的任务是从这些表示中找到字典序最小的序列,即该序列的"最小表示"。

例如:碱基序列 ATCA 从不同位置读取可能的表示有 ATCA, TCAA, CAAT, AATC,其中 AATC 是字典序最小的表示。

测试样例

样例1:

输入:dna_sequence = "ATCA"

输出:'AATC'

样例2:

输入:dna_sequence = "CGAGTC"

输出:'AGTCCG'

样例3:

输入:dna_sequence = "TTGAC"

输出:'ACTTG'

方法一:枚举法

java 复制代码
public class Main {
    public static String solution(String dna_sequence) {
        // Please write your code here
        int A_num = 0;
        for(char ch : dna_sequence.toCharArray()){
            if(ch == 'A') A_num++;
        }
        if(A_num != 0){
            String res = dna_sequence;
            for(int i = 0;i < A_num;i++){
                int index = dna_sequence.indexOf('A');
                dna_sequence = dna_sequence.substring(index)+dna_sequence.substring(0,index);
                res = MinString(res,dna_sequence);
                if(dna_sequence.charAt(0) == 'A'){
                    dna_sequence = dna_sequence.substring(1) + 'A';
                }
            }
            return res;
        }
        int C_num = 0;
        for(char ch : dna_sequence.toCharArray()){
            if(ch == 'C') C_num++;
        }
        if(C_num != 0){
            String res = dna_sequence;
            for(int i = 0;i < C_num;i++){
                int index = dna_sequence.indexOf('C');
                dna_sequence = dna_sequence.substring(index)+dna_sequence.substring(0,index);
                res = MinString(res,dna_sequence);
                if(dna_sequence.charAt(0) == 'C'){
                    dna_sequence = dna_sequence.substring(1) + 'C';
                }
            }
            return res;
        }
        int G_num = 0;
        for(char ch : dna_sequence.toCharArray()){
            if(ch == 'G') G_num++;
        }
        if(G_num != 0){
            String res = dna_sequence;
            for(int i = 0;i < G_num;i++){
                int index = dna_sequence.indexOf('G');
                dna_sequence = dna_sequence.substring(index)+dna_sequence.substring(0,index);
                res = MinString(res,dna_sequence);
                if(dna_sequence.charAt(0) == 'G'){
                    dna_sequence = dna_sequence.substring(1) + 'G';
                }
            }
            return res;
        }
        return dna_sequence;
    }

    private static String MinString(String res, String dna_sequence) {
        if(res.equals(dna_sequence)) return res;
        for(int i = 0;i < res.length();i++){
            if(res.charAt(i) < dna_sequence.charAt(i)){
                return res;
            }
            if(res.charAt(i) > dna_sequence.charAt(i)){
                return dna_sequence;
            }
        }
        return res;
    }

    public static void main(String[] args) {
        // You can add more test cases here
        System.out.println(solution("ATCA").equals("AATC"));
        System.out.println(solution("CGAGTC").equals("AGTCCG"));
        System.out.println(solution("TCATGGAGTGCTCCTGGAGGCTGAGTCCATCTCCAGTAG").equals("AGGCTGAGTCCATCTCCAGTAGTCATGGAGTGCTCCTGG"));
    }
}
相关推荐
AndrewHZ15 分钟前
【遥感图像入门】遥感图像专用去噪算法:核心方案与实战(PyTorch代码)
pytorch·算法·计算机视觉·cv·遥感图像·高分辨率·去噪算法
是梦终空15 分钟前
JAVA毕业设计253—基于Java+Springboot+vue3+协同过滤推荐算法的传统服饰文化平台(源代码+数据库+任务书+12000字论文)
java·spring boot·vue·毕业设计·课程设计·协同过滤推荐算法·传统服饰文化平台
前端小L1 小时前
回溯算法专题(八):精细化切割——还原合法的「IP 地址」
数据结构·算法
Hcoco_me7 小时前
大模型面试题17:PCA算法详解及入门实操
算法
跨境卫士苏苏7 小时前
亚马逊AI广告革命:告别“猜心”,迎接“共创”时代
大数据·人工智能·算法·亚马逊·防关联
HerayChen7 小时前
HbuilderX 内存溢出报错
java·大数据·linux
程序员小白条8 小时前
0经验如何找实习?
java·开发语言·数据结构·数据库·链表
云雾J视界8 小时前
当算法试图解决一切:技术解决方案主义的诱惑与陷阱
算法·google·bert·transformer·attention·算法治理
Xの哲學8 小时前
Linux Miscdevice深度剖析:从原理到实战的完整指南
linux·服务器·算法·架构·边缘计算
小马爱打代码8 小时前
Spring AI:搭建自定义 MCP Server:获取 QQ 信息
java·人工智能·spring