01数字串
提交数: 174, 通过率: 61.49%, 平均分: 64.48
题目描述:
有一串只包含“0” 、 “1” 的数字串 s(长度不超过 1000) , 现要从数字串 s 中截取一段数字子串(该子串一定存在), 使得数字子串中“0” 、 “1” 的数量相等。
编写程序, 求数字串 s 中满足上述要求的最长数字子串的长度及其在数字串 s 中的位置(若有多个相同的最长长度, 取第一次出现的位置)。
输入格式:
一个01串
输出格式:
输出两行,第一行最多的长度,第二行 数字串 s 中的位置
样例输入:
01100
样例输出:
4 0 3
提示:
请完善程序:
#include<bits/stdc++.h>
using namespace std;
char a[1001], c ;
int n, p, maxn, b[1001];
int main(){
ios::sync_with_stdio( 0 ), cin.tie( 0), cout.tie(0); //读入优化
while ( cin >> c ){
n = n+1;
a[n] = c;
}
for ( int i=1; i<=n; i++) //求前缀和 b[]
______________________________
for ( int i=1; i<n; i++){ //枚举起点
for ( int j=i+1; j<=n; j++){ //枚举终点
int x = ______________, y = _____________________; //分别求该区间内0的个数,及1的个数。
if ( x == y ) { //如果这区间内0的个数和与1的个数相等,并且长度更长,那么更新最优值
___________________
}
}
}
cout << maxn << endl;
cout << p-1 << " " << p+maxn - 1 -1 ;
return 0;
}
时间限制: 1000ms
空间限制: 256MB