Submission #643

#TimeUsernameProblemLanguageResultExecution timeMemory
643jwvg0425파일 삭제 (GA3_delete)C++98
25 / 120
1 ms936 KiB
#include <algorithm> struct F{int a,b;}; F D[3000]; void addFile(int i, int* B) { D[i].a++; if(i==0) return; addFile(B[i],B); } void UpDelete(int i,int r,int M,int* B) { int k; for(k=0;D[k].b!=i;k++); D[k].a-=r; if(B[i]==-1) return; UpDelete(B[D[k].b],r,M,B); } void deleteDir(int i,int M,int* B) { int j,k,t=0; for(k=0;D[k].b!=i;k++); D[k].a=0; for(j=0;j<M;j++) { if(B[j]==D[k].b) { deleteDir(j,M,B); } } } int Compare(const void* a,const void* b) { return ((F*)b)->a-((F*)a)->a; } int DeletePlan(int N,int M, int K, int* A,int* B) { int i,s=0,t; for(i=0;i<N;i++) { addFile(A[i],B); } for(i=0;i<M;i++) { D[i].b=i; } qsort(D,M,sizeof(F),Compare); for(i=0;i<M;i++) { if(D[i].a<=K&&D[i].a!=0) { K-=D[i].a; UpDelete(B[D[i].b],D[i].a,M,B); deleteDir(D[i].b,M,B); qsort(D,M,sizeof(F),Compare); s++; i=-1; } } s+=K; return s; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...