Submission #472395

#TimeUsernameProblemLanguageResultExecution timeMemory
472395AbhishekPathakRabbit Carrot (LMIO19_triusis)C++17
100 / 100
107 ms5304 KiB
#include <iostream> #include <vector> #include <algorithm> using std::cout; using std::endl; using std::vector; int longest_nondec_subseq(const vector<int>& seq) { vector<int> min_endings; for (int i : seq) { // note that we use upper_bound instead of lower_bound bc it just has to be nondecreasing int pos = std::upper_bound(min_endings.begin(), min_endings.end(), i) - min_endings.begin(); // standard LIS protocol if (pos == min_endings.size()) { min_endings.push_back(i); } else { min_endings[pos] = i; } } return min_endings.size(); } int main() { int pole_num; int jump_height; std::cin >> pole_num >> jump_height; vector<int> poles(pole_num); for (int p = 0; p < pole_num; p++) { std::cin >> poles[p]; } vector<int> poss_unchanged; for (int i = 1; i <= pole_num; i++) { // only add if it has any hope of being unchanged if (i * jump_height >= poles[i - 1]) { poss_unchanged.push_back(i * jump_height - poles[i - 1]); } } cout << pole_num - longest_nondec_subseq(poss_unchanged) << endl; }

Compilation message (stderr)

triusis.cpp: In function 'int longest_nondec_subseq(const std::vector<int>&)':
triusis.cpp:15:11: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   15 |   if (pos == min_endings.size()) {
      |       ~~~~^~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...