牛客算法:DNA序列

import java.util.*;
public class Main{
    public static void main(String[] args){
       try(Scanner in = new Scanner(System.in)){
           String s = in.next();
           System.out.println(fun(s));
       }
    }
    /*
        思路是从字符串中分别截取所有长度为1,2,3,4,...的字符串,然后与可能的DNA子串进行匹配
        长度1的子串:A,G,T,C 共4个
        长度2的子串:AA,AG,AT,AC;GA,GG,GT,GC..共4*4个
        长度3的子串:AAA,AAG,AAT,AAC. 共4*4*4个
        我们无需一一比较s中是否有具体的哪些子串,我们只需要知道:在比较到如第2个级别,是否有16个两两不同的子串即可
    */
    public static int fun(String s){
        Set<String> set = new HashSet<String>();
        int i = 0;
        int j = 1;  //表示查找级别,也就是长度为j的子串
        int cnt = 4;
        while(j < s.length()){
            i = 0;  //不管你比较到哪个级别,你都需要从最开头来截取片段
            while(i + j <= s.length()){  //i+j是你substring的后一个参数,自然要不大于s.length()
                set.add(s.substring(i,i+j));
                if(set.size()>=cnt) break;  //已经找到当前级别的所有组合,无需继续分割了
                i++;
            }
            if(set.size() < cnt) break;  //如果当前级别j没有找到对应级别的种数,没必要查找下一级别了
            set.clear();  //如果当前级别满足,那就清空set,继续下一级别的判断
            j++;
            cnt *= 4; //进入下一级别,种类又翻了四倍
        }
        return j;
    }
}
牛客算法:DNA序列的更多相关文章
- 牛客 - 17968 - xor序列 - 线性基
		https://ac.nowcoder.com/acm/problem/17968 下面是错误的做法,因为题目要求必须使用x,而y在check的时候不一定用到等价于x的线性基来构成. 正确的做法是直接 ... 
- 牛客算法周周练20   F.紫魔法师   (二分图染色)
		题意:给你一张图,对其染色,使得相连的点的颜色两两不同求,最少使用多少种颜色. 题解:首先,若\(n=1\),只需要一种.然后我们再去判断是否是二分图,对于二分图,两种颜色就够了,若不是二分图,也就是 ... 
- 牛客寒假算法基础集训营2 【处女座与复读机】DP最小编辑距离【模板题】
		链接:https://ac.nowcoder.com/acm/contest/327/G来源:牛客网 一天,处女座在牛客算法群里发了一句“我好强啊”,引起无数的复读,可是处女座发现复读之后变成了“处女 ... 
- 牛客练习赛26  D	xor序列 (线性基)
		链接:https://ac.nowcoder.com/acm/contest/180/D 来源:牛客网 xor序列 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他 ... 
- 牛客网《BAT面试算法精品课》学习笔记
		目录 牛客网<BAT面试算法精品课>学习笔记 牛客网<BAT面试算法精品课>笔记一:排序 牛客网<BAT面试算法精品课>笔记二:字符串 牛客网<BAT面试算法 ... 
- 牛客练习赛47  DongDong数颜色 (莫队算法)
		链接:https://ac.nowcoder.com/acm/contest/904/E 来源:牛客网 DongDong数颜色 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 5242 ... 
- 牛客小白月赛12  J	月月查华华的手机 (序列自动机模板题)
		链接:https://ac.nowcoder.com/acm/contest/392/J 来源:牛客网 题目描述 月月和华华一起去吃饭了.期间华华有事出去了一会儿,没有带手机.月月出于人类最单纯的好奇 ... 
- 利用Needleman–Wunsch算法进行DNA序列全局比对
		生物信息学原理作业第二弹:利用Needleman–Wunsch算法进行DNA序列全局比对. 具体原理:https://en.wikipedia.org/wiki/Needleman%E2%80%93W ... 
- Applese 的毒气炸弹 G 牛客寒假算法基础集训营4(图论+最小生成树)
		链接:https://ac.nowcoder.com/acm/contest/330/G来源:牛客网 Applese 的毒气炸弹 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262 ... 
随机推荐
- golang json解析到map中
			package main import ( "fmt" "encoding/json" ) type ItemMessage struct { ItemType ... 
- Hbuilder连接苹果手机
			最简单的连接方法 1 手机电脑连接---usb 2 pc下载iTunes 3 信任电脑,手机信任设备(设置--->通用--->设备管理-->信任) 4 ... 
- 阿里云RocketMQ的生产者简单实现
			// MQ的应用场景有比如 订单变更消息可以通过产生这个事件的地方(比如前端调用后端的接口post一个订单,那么就是在这个mapping方法里做一个生产者[不过最好通过aop来实现,不然n多个接口都要 ... 
- ASP.NET请求过程-Module
			管道模型 上图中为Http请求在Asp.net程序中处理的过程.管道处理模型来自上面的HttpApplication,管道处理模型其实就是多个Module(其实这些module都是在往http ... 
- jmeter BeanShell实例-----两个变量之间的断言对比(转)
			jmeter BeanShell实例-----两个变量之间的断言对比 在jmeter的中,断言没法对两个变量的进行对比后判断,只能使用Bean Shell断言来进行,总是有人来问怎么写呢.这里写一个简 ... 
- jenkins sonarqube 代码检测部署
			install pgsql and sonarqube docker run --name postgresqldb -e POSTGRES_USER=sonar -e POSTGRES_PASSWO ... 
- Fabric中的节点类型
			在Fabric中,尽管所有对等节点/peer都是相同的,但它们可以根据网络的配置方式承担多个角色:(①②是主要的节点类型) ①提交节点: 通道中的每个对等节点都是一个提交节点.它们接收生成的交易区块, ... 
- SSH框架CRUD+树形菜单案例
			今天结合了案例来写ssh的增删改查 表设计 t_ssh_tree t_vue_user book 核心配置文件 struts-base.xml <?xml version="1.0 ... 
- golang跨平台编译
			// 目标平台linux 64 SET CGO_ENABLED=0 SET GOOS=linux SET GOARCH=amd64 go build //目标平台windows SET CGO_ENA ... 
- Linux下/etc/login.defs文件
			/etc/login.defs文件定义了与/etc/password和/etc/shadow配套的用户限制设定.这个文件是需要的,缺失并不会影响系统的使用,但是也许会产生意想不到的错误. 如果/etc ... 
