题解 | DNA序列

import  java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner in=new Scanner(System.in);
        String s=in.nextLine();
        int n=in.nextInt();

        int max=0,index=0;
        int i;
        for (i = 0; i < s.length(); i++) {
            int len=0;
            for (int j = i; j < i+n; j++) {
                if(j+1==s.length()) break;
                if(s.charAt(j)=='C'||s.charAt(j)=='G') len++;
            }
            if(max<len) {
                max=len;
                index=i;
            }
        }
        System.out.println(s.substring(index,index+n));
    }
}

只遍历一遍。

使用两层循环,第一层用来控制开头,第二层用来控制长度,并计算C和G出现在此子字符串中出现的次数。

在第二层循环外与max比较,若比max大,则更新max+用index记录此时的位置,留着后面在此字符串直接输出。

全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务