1529 - 基因锁

题目描述

小X终于意识到需要花大力气减重了,他询问了若干个减重专家后决定采用最适合年轻人的运动减重方案,考虑再三,小X最终选择了打羽毛球的方式,一个原因是小X的小伙伴大都喜欢打羽毛球,其次是打羽毛球要抬头,对活动颈椎有好处,刚好可以缓冲编程久了对颈椎的压迫。

经过一个月的努力,小X的国际象棋 ��AI 在机器学习的环境中进步神速,已经能够轻松战胜深蓝了,但小X的体重却没有太大变化,离第一目标 Q 老师尚有一段距离,这天小X跟往常一样白天打羽毛球,晚上训练 ��AI 后就睡觉了,睡梦中小X梦见自己先是被一束强光罩住了,随后被吸进了 ���UFO,落到了 ���UFO 的甲板上,只见一只会说人话的机器狗迎上前来,对小X说:“小X先生好,我家主人在会客舱等你多时了!”

随后小X被带到了一位长了三只眼的外星首领面前。

外星首领很友善地和小X握了手,然后对小X说:“你做的 ��AI 非常棒,我已经很多年未遇对手了,今天跟你的 ��AI 打得旗鼓相当,十分过瘾,这次请你来作客是想和你交个朋友,你有什么要求尽管提,我们会尽量满足!”小X听罢受宠若惊,心想外星科技这么发达,也许有办法让我立刻变得像中天学长一样帅!

于是小X提出了这个超高难度的要求,外星首领听后微微一笑:“你这个要求可以满足,但我们要对你的基因进行一次分析,把你基因中的肥胖基因找出来,然后给它们加上锁!象我们熟知的那样,人类的基因序列(英文缩写为 DNA)是一个由字母'A','C','G','T'组成的字符串,肥胖基因是其中的一个子串(子串为原串中一段连续的字符),外星人对小X的基因手术过程是这样的:先找出所有的肥胖基因,并将它们用基因墨水染成红色,然后将某些字符加上基因锁,一把基因锁只能锁住一个字符,一个肥胖基因只要有一个字符加上了基因锁,则这个肥胖基因就不再起作用。

现在要你计算有多少个字符被基因墨水染成了红色?最少需要多少把基因锁才能将所有的肥胖基因锁住?

输入

第一行包含两个用空格隔开的正整数 �1L1​,�2L2​,表示小X基因的长度和肥胖基因的长度。

第二行为一个长度为 �1L1​ 的字符串,表示小X的基因。

第三行为一个长度为 �2L2​ 的字符串,表示肥胖基因。数据保证 �1>�2L1​>L2​。

输出

输出一行包含两个整数,表示被基因墨水染成了红色的字符个数和所需的基因锁数量,两数之间严格用一个空格隔开。

样例
输入复制
16 3
CGCGCATCGCATTAGG
CGC
输出复制
8 2


#include<bits/stdc++.h>
using namespace std;
int a[1000100],n,m,sum,ans;
string str,s;
int main() {
	cin >> n >> m >> str >> s;
	for(int i=0;i<n;i++){
		if(str.substr(i,m)==s){
			int f = 1;
			for(int j=i;j<i+m;j++){
				if(a[j]==0){
					sum++;
					a[j]=1;
				}
				if(a[j]==2){
					f = 0;
				}
			}
			if(f) a[i+m-1]=2,ans++;
		}
	}
	cout << sum << " " << ans;
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三块不一样的石头

十分满意,一分打赏~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值