Submission #548932

#TimeUsernameProblemLanguageResultExecution timeMemory
548932ala2Street Lamps (APIO19_street_lamps)C++14
0 / 100
391 ms85868 KiB
#include <bits/stdc++.h>
#define int long long
#define pb push_back
using namespace std;
//int a[1001000];
string s;
int n,T;
vector<pair<int,int>>anss;
vector<int>v[1000100];
vector<int>von[1000100];
vector<int>vtype[1001000];
int bit(int i)
{
    return s[i]=='1'&&s[i+1]=='1';
}
char f(char x)
{
    if(x=='1')
    {
        return '0';
    }
    else return '1';
}
signed main()
{
    cin>>n>>T;
    cin>>s;
    // A 1 B 2
    s+='1';
    for(int i=0;i<n;i++)
    {
        v[i].pb(0);
        vtype[i].pb(1);
        if(s[i]=='1'&&s[i+1]=='1')
        {
            von[i].pb(1);
        }
        else von[i].pb(0);
    }
    for(int q=1;q<=T;q++)
    {
        string c;
        cin>>c;
        if(c[0]=='q')
            c='B';
        else c='A';
        if(c=="A")
        {
            int i;
            cin>>i;
            i--;
            s[i]=f(s[i]);
            int nw=bit(i);
            v[i].pb(q);
            vtype[i].pb(1);
            von[i].pb(nw);
            continue;

        }
        int a,b;
        cin>>a>>b;
        a--;
        b--;
        int i=a;
        v[i].pb(q);

        int x=von[i].size();
        while(!x)
        {

        }
        von[i].pb(von[i][x-1]);
        vtype[i].pb(2);
    }
    for(int i=0;i<n;i++)
    {
        von[i][0]=0;
    }
    /*
    for(int i=0;i<=n;i++){
    for(auto j:v[i])
    cout<<j<<" ";
    cout<<endl;


    }
    cout<<endl;
    for(int i=0;i<=n;i++){
    for(auto j:von[i])
    cout<<j<<" ";
    cout<<endl;

    }
    cout<<endl;
    for(int i=0;i<=n;i++){
    for(auto j:vtype[i])
    cout<<j<<" ";
    cout<<endl;


    }
    */
    for(int i=0;i<=n;i++)
    {
        int g=0;
        for(int j=1;j<v[i].size();j++)
        {       // cout<<"        "<<i<<endl;


            if(von[i][j-1]==1)
             g+=v[i][j]-v[i][j-1];
            if(vtype[i][j]==2)
            {
                int x=g;
                if(v[i][j]==1&&von[i][j])
                    x++;
                anss.pb({v[i][j],x});
            }
        }
    }
    sort(anss.begin(),anss.end());
    for(auto i:anss)
    {
        cout<<i.second<<endl;
    }

}

// 2 6 11 q 1 2 t 1 q 1 2 q 1 2 t 1 q 1 2


Compilation message (stderr)

street_lamps.cpp: In function 'int main()':
street_lamps.cpp:106:22: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  106 |         for(int j=1;j<v[i].size();j++)
      |                     ~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...