[luogu] CF165C Another Problem on Strings 类DP

前言

传送门 :

思路

本人太菜,丝毫没感觉是一道模拟QAQ

前置知识 : 子串是连续的

我们先做这题之前,先计算一下如下 :
k = = 1 k == 1 k==1的时候,发现都是 3 3 3
100 = 3 100 = 3 100=3
001 = 3 001 = 3 001=3
010 = 3 010 = 3 010=3

也就是说,我们其实对于这种 010 010 010 100 100 100

其实都是可以将 0 0 0放在前面统计的

因此这样子 这道题目就变成了一道模拟

我们只需要每次遇到 1 1 1的时候,统计一下前面 0 0 0的个数即可

CODE

const int N  = 1e6+10;
int dp[N];



ll ans ; 
int cnt,k;
string s;
            
int change_int(char a)
{
	return a-'0';
}
void solve()
{
	dp[0] = 1;
		
	cin>>k;
	cin>>s;
	
	int len  =s.size();
	for(int i=0;i<len;i++)
	{
	int op = change_int(s[i]);
		
	 if(op == 1)
		 cnt++;
	 if(cnt>=k)
	  ans+=dp[cnt-k];
	
	 dp[cnt]++;	
	}
	cout<<ans<<endl;
	
}
int main()
{
    //int t;cin>>t;while(t -- )
    solve();
    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值