列表

详情


NC214436. 肥猪的钢琴床

描述

肥猪很喜欢睡懒觉,与此同时肥猪十分喜欢买各种各样神奇的床。

今天肥猪买了一张很宽很宽的钢琴床,肥猪就在上面滚来滚去。
这张钢琴床十分的有趣,因为它被分为n个部分,每一个部分是凸起来或者凹下去的,可是肥猪十分不喜欢相邻两个位置高低不同,因为他会滚不过去。
肥猪从小就很喜欢这样的一句谚语:猪往高处走,水往低处流,所以肥猪很喜欢凸起来的部分而不喜欢凹下去的部分。
现在肥猪可以把床中的某一些部分拿走,以让剩余部分所有凸起来的部分都是连起来的,这样肥猪就会很开心,因为他又可以滚来滚去了。
肥猪希望移除的部分最少

我们假设0表示某一个位置是凹下去的,1表示某一个位置是凸起来的。

那么
0
1
00111
01111000
11100
都是肥猪喜欢的钢琴床,因为所有凸起来的部分都是连续的

如果是
101
010011
1111101
就是肥猪不喜欢的钢琴床,因为所有凸起来的部分不是连续的
对于第一张床,肥猪可以把第二个位置拿走,这样床就变成了11。
对于第二张床,肥猪可以把第二个位置拿走,这样床就变成了00011。


输入描述

读入一共有两行,第一行只有一个正整数数n,表示钢琴床有n个部分。
第二行由一个01串组成
* n<=1000000
* 保证01串的长度为n

输出描述

输出一个正整数表示肥猪最少要拿走的部分的数量

示例1

输入:

10
0001111000

输出:

0

示例2

输入:

3
101

输出:

1

示例3

输入:

6
010011

输出:

1

原站题解

上次编辑到这里,代码来自缓存 点击恢复默认模板

C++(g++ 7.5.0) 解法, 执行用时: 29ms, 内存消耗: 2464K, 提交时间: 2022-11-11 08:53:07

#include<bits/stdc++.h>
using namespace std;
string s;
int tot1,tot2,n,tot,maxn=-1;
int main(){
	cin>>n>>s;
	for(int i=0;i<n;i++){
		if(s[i]=='1')tot1++,tot++;
		else tot2++;
		if(tot2>=tot1){
			tot1=tot2=0;
		}
		maxn=max(maxn,tot1-tot2);
	}
	cout<<tot-maxn;
}

C 解法, 执行用时: 7ms, 内存消耗: 1200K, 提交时间: 2021-09-28 17:42:08

#include<stdio.h>
int main()
{
	int n,i,x=0,a=0,b=0;
	char c[1000001];
	scanf("%d",&n);
	scanf("%s",c);
	for(i=0;i<n;i++)
		if(c[i]=='1')	x++;
	for(i=0;i<n;i++)
	{
		if(c[i]=='1')	a++;
		else a--;
		if(a<0)	a=0;
		if(a>b)	b=a;
	}	
	printf("%d",x-b);
	return 0;
}

C++(clang++ 11.0.1) 解法, 执行用时: 28ms, 内存消耗: 2468K, 提交时间: 2022-08-21 09:38:28

#include <iostream>
using namespace std;

int main(){
	int n;
	string a;
	cin>>n>>a;
	int t=0,p=0,m=0;
	for(int i=0;i<n;i++){
		
		if(a[i]=='1'){
			t++;
			p++;
		}else{
			p--;
		}
		
		if(p<0)p=0;
		
		m=max(m,p);
	}
	cout<<t-m;
	return 0;
}

上一题