Submission #11202

#TimeUsernameProblemLanguageResultExecution timeMemory
11202dohyun0324역사적 조사 (JOI14_historical)C++98
40 / 100
4000 ms9804 KiB
#include<stdio.h> #include<math.h> #include<string.h> #include<vector> #include<algorithm> using namespace std; int s2,f,w,r,p,cnt,x,y,n,m,k,pos[100010],arr[100010],ch[100010]; long long dap,big; struct data{ int x,y; bool operator<(const data&r)const{ if(x==r.x) return y<r.y; return x<r.x; } }imsi[100010]; long long b[400][400]; vector<int>a[100010]; int main() { int i,j,s; scanf("%d %d",&n,&m); for(i=1;i<=n;i++){scanf("%d",&arr[i]); imsi[i].x=arr[i]; imsi[i].y=i;} sort(imsi+1,imsi+n+1); for(i=1;i<=n;i++) { if(imsi[i].x!=imsi[i-1].x) cnt++; pos[cnt]=imsi[i].x; arr[imsi[i].y]=cnt; a[cnt].push_back(imsi[i].y); } k=sqrt(n); for(i=1;;i++){ w=i-1; big=0; memset(ch,0,sizeof ch); if(k*(i-1)+1>n) break; for(j=k*(i-1)+1;j<=n;j++){ ch[arr[j]]++; big=max(big,(long long)ch[arr[j]]*(long long)pos[arr[j]]); if(j%k==0){w++; b[i][w]=big;} } if(n%k!=0){w++; b[i][w]=big;} } p=i; for(i=1;i<=m;i++) { scanf("%d %d",&x,&y); f=(x-1)/k+2; r=(y-1)/k; dap=b[f][r]; if(f>r){ for(j=x;j<=y;j++){ s=upper_bound(a[arr[j]].begin(),a[arr[j]].end(),y)-lower_bound(a[arr[j]].begin(),a[arr[j]].end(),x); dap=max(dap,(long long)s*(long long)pos[arr[j]]); } printf("%lld\n",dap); continue; } for(j=x;j<=(f-1)*k;j++) { s=upper_bound(a[arr[j]].begin(),a[arr[j]].end(),y)-lower_bound(a[arr[j]].begin(),a[arr[j]].end(),x); dap=max(dap,(long long)s*(long long)pos[arr[j]]); } for(j=r*k+1;j<=y;j++) { s=upper_bound(a[arr[j]].begin(),a[arr[j]].end(),y)-lower_bound(a[arr[j]].begin(),a[arr[j]].end(),x); dap=max(dap,(long long)s*(long long)pos[arr[j]]); } printf("%lld\n",dap); } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...