This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <iostream>
#include <fstream>
#include <vector>
#include <string>
#include <cstring>
#include <cassert>
using namespace std;
int n, k, cnt=0, durdur=0, sz=0;
int input[1000005];
int p[500005];
vector <int> v[500005];
int main()
{
cin >> n >> k;
for (int i=1;i<=n;i++)
{
char a;
cin >> a;
input[++sz]=i;
if (a=='c')
{
cnt++;
p[cnt]=0;
}
else
{
p[cnt]++;
}
if (cnt && p[cnt]+p[cnt-1]==k)
{
durdur++;
for (int j=sz-k;j<=sz;j++)
{
v[durdur].push_back (input[j]);
}
sz-=k+1;
int ant=p[cnt--];
p[cnt]-=k-ant;
}
}
for (int i=n/(k+1);i>=1;i--)
{
for (auto itr : v[i])
{
cout << itr << " ";
}
cout << "\n";
}
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |