#include <cstdio> #include <vector> #include <algorithm> #define MAKS 100010 using namespace std; char s[MAKS]; vector<int> v; int main() { int t; scanf("%d",&t); for(int q=0;q<t;q++) { int n; scanf("%d %s",&n,s); int a=0; int b=0; int i=0; while(i<n && s[i]=='0')i++; if(i==n) { puts("0"); continue; } a=i; v.clear(); while(i<n) { while(i<n && s[i]=='1')i++; if(i==n)break; int p=i; while(i<n && s[i]=='0')i++; if(i<n)v.push_back(i-p); else b=i-p; } /*printf("a: %d, b: %d\n",a,b); for(int i=0;i<v.size();i++)printf("%d ",v[i]); puts("");*/ sort(v.begin(),v.end(),greater<int>()); int naj=0; for(int x=0;x<4;x++) { int kand=0; int d=0; if(x&1) { kand+=max(a-d,0); d++; } if(x&2) { kand+=max(b-d,0); d++; } for(int i=0;i<v.size();i++) { int o=max(v[i]-2*d,0); if(o>1)o--; kand+=o; d+=2; } if(kand>naj)naj=kand; } printf("%d\n",n-naj); } }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 | #include <cstdio> #include <vector> #include <algorithm> #define MAKS 100010 using namespace std; char s[MAKS]; vector<int> v; int main() { int t; scanf("%d",&t); for(int q=0;q<t;q++) { int n; scanf("%d %s",&n,s); int a=0; int b=0; int i=0; while(i<n && s[i]=='0')i++; if(i==n) { puts("0"); continue; } a=i; v.clear(); while(i<n) { while(i<n && s[i]=='1')i++; if(i==n)break; int p=i; while(i<n && s[i]=='0')i++; if(i<n)v.push_back(i-p); else b=i-p; } /*printf("a: %d, b: %d\n",a,b); for(int i=0;i<v.size();i++)printf("%d ",v[i]); puts("");*/ sort(v.begin(),v.end(),greater<int>()); int naj=0; for(int x=0;x<4;x++) { int kand=0; int d=0; if(x&1) { kand+=max(a-d,0); d++; } if(x&2) { kand+=max(b-d,0); d++; } for(int i=0;i<v.size();i++) { int o=max(v[i]-2*d,0); if(o>1)o--; kand+=o; d+=2; } if(kand>naj)naj=kand; } printf("%d\n",n-naj); } } |