제출 #125274

#제출 시각아이디문제언어결과실행 시간메모리
125274dragonslayeritMountains (IOI17_mountains)C++14
100 / 100
42 ms28024 KiB
#include "mountains.h" #include <vector> #include <algorithm> #include <cstdio> int first[2001][2001];//if i is required int best[2001][2001]; //Is there a case that breaks the algorithm assuming first=best? int maximum_deevs(std::vector<int> y) { for(int i=0;i<y.size();i++){ first[i][i+1]=1; best[i][i+1]=1; } for(int i=y.size()-1;i>=0;i--){ int k=i+1; for(int j=i+2;j<=y.size();j++){ first[i][j]=first[i][k]+best[k+1][j]; best[i][j]=std::max(first[i][j],best[i+1][j]); if(1LL*(k-i)*(y[j]-y[i])>=1LL*(j-i)*(y[k]-y[i])){ k=j; } } } return best[0][y.size()]; }

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

mountains.cpp: In function 'int maximum_deevs(std::vector<int>)':
mountains.cpp:12:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int i=0;i<y.size();i++){
               ~^~~~~~~~~
mountains.cpp:18:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for(int j=i+2;j<=y.size();j++){
                   ~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...