LibreOJ NOIP Round #1 DNA 序列

博客内容介绍了在LibreOJ NOIP Round #1中遇到的一道关于DNA序列的问题。作者首先尝试使用暴力方法结合EKMP算法求解,但未成功。接着,作者提出通过预计算所有可能的碱基序列并利用哈希映射来解决,以此换取空间效率,最终找出最长重复子串的计数。代码实现包括读取DNA序列,计算子串长度,将碱基映射为数值,存储子串出现次数,并找出最大值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

                  LibreOJ NOIP Round #1  DNA 序列


这道题刚开始我的思路就是暴力~~~~~
但是很无奈,TE了
我直接暴力出所有长度为n的子串
然后用EKMP算法算出子串的个数

这道题可以用空间来换时间
因为n很小
那么可以把所有碱基序列可能的情况都列出来
然后for循环一遍,把所有情况都统计一下
最后找出最大值~~~反正只用知道最多重复的个数,并不用知道碱基序列
况且这种方法也是可以反向找碱基序列的

那么如何把所有情况都列出来,而且不重不漏
类比一下哈希算法
可以把A 对应为0 ,G对应为1,C对应为2,T对应为3
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值