#include<iostream>
#include<string>
#include<queue>
#include<utility>
using namespace std;
priority_queue<pair<int,pair<int,int> > > kolejka;
int main()
{
cin.tie(0);
cout.tie(0);
ios_base::sync_with_stdio(0);
int zap;
cin>>zap;
while(zap--)
{
int n;
string s;
cin>>n>>s;
while(!kolejka.empty())
kolejka.pop();
int wynik=0;
int pocz=0,kon=0,gdzie=0,mam=0;
for(int i=0;i<n;i++)
{
if(s[i]=='1')
{
if(mam==1)
{
kolejka.push(make_pair(i-gdzie-1,make_pair(gdzie,i)));
//cout<<"rzucsm "<<i-gdzie-1<<"\n";
gdzie=i;
}
else{
mam=1;
pocz=i;
gdzie=i;
}
}
}
kon=gdzie;
int wiel_pocz=pocz;
int wiel_kon=n-kon-1;
int mam_pocz=0,mam_kon=0;
int czas=0;
if(kolejka.size()==0)
{
cout<<"0\n";
continue;
}
//cout<<wiel_pocz<<" "<<wiel_kon<<"\n";
while(!kolejka.empty())
{
pair<int,pair<int,int> > para;
para=kolejka.top();
int zmiana;
if(para.first-2*czas>2)
zmiana=para.first-2*czas-1;
else if(para.first-2*czas>=1)
zmiana=1;
else zmiana=0;
//cout<<para.first<<" "<<para.second.first<<" "<<para.second.second<<"\n";
if(wiel_pocz-czas>=zmiana-1 && wiel_pocz-czas>0 && (wiel_pocz-czas>=wiel_kon-czas || mam_kon==1) && mam_pocz==0)
{
wynik+=(wiel_pocz-czas);
mam_pocz=1;
//cout<<"robie1\n";
}
else if(wiel_kon-czas>=zmiana-1 && wiel_kon-czas>0 && (wiel_kon-czas>=wiel_pocz-czas || mam_pocz==1) && mam_kon==0)
{
wynik+=(wiel_kon-czas);
mam_kon=1;
//cout<<"robie2\n";
}
else if(para.first-2*czas>0)
{
if(para.first-2*czas<=2)
wynik++;
else{
wynik+=(para.first-2*czas-1);
}
kolejka.pop();
//cout<<"robei3\n";
czas++;
}
else kolejka.pop();
czas++;
//cout<<"aktualny wynik: "<<wynik<<"\n";
}
//cout<<"ZAOKNCZENIE\n";
//cout<<pocz<<" "<<kon<<"\n";
cout<<n-wynik<<"\n";
}
return 0;
}
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 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 | #include<iostream> #include<string> #include<queue> #include<utility> using namespace std; priority_queue<pair<int,pair<int,int> > > kolejka; int main() { cin.tie(0); cout.tie(0); ios_base::sync_with_stdio(0); int zap; cin>>zap; while(zap--) { int n; string s; cin>>n>>s; while(!kolejka.empty()) kolejka.pop(); int wynik=0; int pocz=0,kon=0,gdzie=0,mam=0; for(int i=0;i<n;i++) { if(s[i]=='1') { if(mam==1) { kolejka.push(make_pair(i-gdzie-1,make_pair(gdzie,i))); //cout<<"rzucsm "<<i-gdzie-1<<"\n"; gdzie=i; } else{ mam=1; pocz=i; gdzie=i; } } } kon=gdzie; int wiel_pocz=pocz; int wiel_kon=n-kon-1; int mam_pocz=0,mam_kon=0; int czas=0; if(kolejka.size()==0) { cout<<"0\n"; continue; } //cout<<wiel_pocz<<" "<<wiel_kon<<"\n"; while(!kolejka.empty()) { pair<int,pair<int,int> > para; para=kolejka.top(); int zmiana; if(para.first-2*czas>2) zmiana=para.first-2*czas-1; else if(para.first-2*czas>=1) zmiana=1; else zmiana=0; //cout<<para.first<<" "<<para.second.first<<" "<<para.second.second<<"\n"; if(wiel_pocz-czas>=zmiana-1 && wiel_pocz-czas>0 && (wiel_pocz-czas>=wiel_kon-czas || mam_kon==1) && mam_pocz==0) { wynik+=(wiel_pocz-czas); mam_pocz=1; //cout<<"robie1\n"; } else if(wiel_kon-czas>=zmiana-1 && wiel_kon-czas>0 && (wiel_kon-czas>=wiel_pocz-czas || mam_pocz==1) && mam_kon==0) { wynik+=(wiel_kon-czas); mam_kon=1; //cout<<"robie2\n"; } else if(para.first-2*czas>0) { if(para.first-2*czas<=2) wynik++; else{ wynik+=(para.first-2*czas-1); } kolejka.pop(); //cout<<"robei3\n"; czas++; } else kolejka.pop(); czas++; //cout<<"aktualny wynik: "<<wynik<<"\n"; } //cout<<"ZAOKNCZENIE\n"; //cout<<pocz<<" "<<kon<<"\n"; cout<<n-wynik<<"\n"; } return 0; } |
English