제출 #876454

#제출 시각아이디문제언어결과실행 시간메모리
876454alexdd순열 (APIO22_perm)C++17
0 / 100
357 ms1544 KiB
#include<iostream> #include<vector> #include<algorithm> #include "perm.h" const int NRIT = 10; const int MAXLUN = 10; const int MINLUN = 4; using namespace std; vector<pair<long long,vector<int>>> secvs; bool cmp(pair<long long,vector<int>> x, pair<long long,vector<int>> y) { if(x.first > y.first) return 1; if(x.first < y.first) return 0; if((int)x.second.size()<(int)y.second.size()) return 1; return 0; } long long dp[MAXLUN+5]; long long calc_nrs(vector<int> v) { for(int i=0;i<=(int)v.size();i++) dp[i]=0; dp[0]=1; for(int i=0;i<(int)v.size();i++) { for(int j=0;j<v[i];j++) dp[v[i]] += dp[j]; } long long nrs=0; for(int i=0;i<=(int)v.size();i++) nrs += dp[i]; return nrs; } void get_secvs() { vector<int> aux; for(int i=1;i<60;i++) { aux.clear(); for(int j=0;j<i;j++) aux.push_back(j); secvs.push_back({(1LL<<i)-1, aux}); } for(int lun=MINLUN;lun<=MAXLUN;lun++) { aux.clear(); for(int i=0;i<lun;i++) aux.push_back(i); for(int i=0;i<NRIT;i++) { random_shuffle(aux.begin(),aux.end()); secvs.push_back({calc_nrs(aux),aux}); } } sort(secvs.begin(),secvs.end(),cmp); } std::vector<int> construct_permutation(long long k) { get_secvs(); vector<int> sol; int cnt=0; k--; for(int i=0;i<secvs.size();i++) { while(k>=secvs[i].first) { for(int j=(int)secvs[i].second.size()-1;j>=0;j--) sol.push_back(cnt+secvs[i].second[j]); cnt += (int)secvs[i].second.size(); k -= secvs[i].first; } } reverse(sol.begin(),sol.end()); return sol; }

컴파일 시 표준 에러 (stderr) 메시지

perm.cpp: In function 'std::vector<int> construct_permutation(long long int)':
perm.cpp:65:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, std::vector<int> > >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   65 |     for(int i=0;i<secvs.size();i++)
      |                 ~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...