上海计算机学会2022年6月月赛C++丙组T4连续的零

题目描述

给定一个 01 序列 b1​b2​...bn​,01 的意思就是这个数列里只有 01

请问最少需要将多少个 1 改成 0,序列里会出现至少 k 个连续的 0

输入格式
  • 第一行:两个整数 n 与 k。
  • 第二行:n 个字符表示 b1b2...bn,保证只出现 01
输出格式

单个整数:最少要改多少个 1,才会出现 k 个连续的 0

数据范围
  • 对于 30%30% 的数据,1≤k≤n≤20;
  • 对于 60%60% 的数据,1≤k≤n≤2000;
  • 对于 100%100% 的数据,1≤k≤n≤500,000
样例数据

输入:

6 3

101010

输出:

1

说明:

改最后一个1

输入:

5 5

00100

输出:

1

题解:

本题关键点:滑动窗口法来解。代码如下。

cpp 复制代码
#include <iostream>
using namespace std;
int  main(){
	string s;	
	int size=0;
	int n, k;
	cin >> n >> k;
	cin >> s;
	int ans=n;
	for(int left=0,right=0;right<n;right++){
		//进窗口
		if(s[right]=='1') size++;
		if(right-left==k){
			//出窗口
			if(s[left]=='1') size--;
			left++;
		}
		if(right>=k-1){
			ans=min(ans,size);
		}	
	}
	cout<<ans<<endl;
	return 0;
}
相关推荐
小字节,大梦想31 分钟前
【C++】二叉搜索树
数据结构·c++
吾名招财33 分钟前
yolov5-7.0模型DNN加载函数及参数详解(重要)
c++·人工智能·yolo·dnn
我是哈哈hh1 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
憧憬成为原神糕手1 小时前
c++_ 多态
开发语言·c++
郭二哈1 小时前
C++——模板进阶、继承
java·服务器·c++
Tisfy1 小时前
LeetCode 2187.完成旅途的最少时间:二分查找
算法·leetcode·二分查找·题解·二分
挥剑决浮云 -1 小时前
Linux 之 安装软件、GCC编译器、Linux 操作系统基础
linux·服务器·c语言·c++·经验分享·笔记
Mephisto.java1 小时前
【力扣 | SQL题 | 每日四题】力扣2082, 2084, 2072, 2112, 180
sql·算法·leetcode
robin_suli1 小时前
滑动窗口->dd爱框框
算法
丶Darling.2 小时前
LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
数据结构·c++·学习·算法·leetcode·二叉树