이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
int n,l,i,v[10005],nr,q,smen[10005][105],solutie[10005][105],j,numar,k,st,dr,mij,sol;
struct wow
{
int poz,val;
}query[105];
map <int,int> m;
bool compare (wow a,wow b)
{
return a.val<b.val;
}
int main()
{
ios_base :: sync_with_stdio(false);
cin.tie(0);
#ifdef HOME
ifstream cin("date.in");
ofstream cout("date.out");
#endif // HOME
cin>>n>>l;
for (i=1;i<=n;i++)
{
cin>>v[i];
m[v[i]]=1;
}
cin>>q;
for (i=1;i<=q;i++)
{
cin>>query[i].val;
query[i].poz=i;
}
sort (query+1,query+q+1,compare);
nr=0;
for (auto ind : m)
{
nr++;
m[ind.first]=nr;
}
for (i=1;i<=n;i++)
{
v[i]=m[v[i]];
}
for (i=1;i<=n-l+1;i++)
{
for (j=i+1;j<=n-l+1;j++)
{
numar=0;
for (k=1;k<=l;k++)
{
if (v[i+k-1]!=v[j+k-1])
{
numar++;
}
}
st=1;
dr=q;
sol=0;
while (st<=dr)
{
mij=(st+dr)/2;
if (query[mij].val<numar)
{
sol=mij;
st=mij+1;
}
else
{
dr=mij-1;
}
}
smen[i][sol+1]++;
smen[j][sol+1]++;
}
}
for (i=1;i<=n-l+1;i++)
{
for (j=1;j<=q;j++)
{
smen[i][j]+=smen[i][j-1];
solutie[i][query[j].poz]+=smen[i][j];
}
}
for (j=1;j<=q;j++)
{
for (i=1;i<=n-l+1;i++)
{
cout<<solutie[i][j]<<" ";
}
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... |