Submission #51544

#TimeUsernameProblemLanguageResultExecution timeMemory
51544KubalionzzaleOBELISK (NOI14_obelisk)C++14
5 / 25
104 ms1896 KiB
#include <iostream> #define int long long int int abss(int x) { if (x < 0) return -x; else return x; } int calc(std::pair<int, int> from, std::pair<int, int> to, int m) { int length = abss(from.first - to.first); int overfirst = ((length / m) + 1) * m; int underfirst = (length / m) * m; int firstDiff = 1e15; if (underfirst == length) { if (length == 0) firstDiff = 0; else firstDiff = (length / m) * 2 + 2; } else { firstDiff = std::min(overfirst - length + ((length / m) + 1) * 2, length - underfirst + (length / m) * 2) + 2; } // std::cout << firstDiff << " "; length = abss(from.second - to.second); overfirst = ((length / m) + 1) * m; underfirst = (length / m) * m; int secondDiff = 1e15; if (underfirst == length) { if (length == 0) secondDiff = 0; else secondDiff = (length / m) * 2 + 2; } else { secondDiff = std::min(overfirst - length + ((length / m) + 1) * 2, length - underfirst + (length / m) * 2) + 2; } // std::cout << secondDiff << "\n"; return firstDiff + secondDiff; } main() { int k, m; std::cin >> k >> m; std::pair<int, int> hole[510][110]; int mini[510][110]; int holeNumber[510]; std::pair<int, int> start, ende; std::cin >> start.first >> start.second >> ende.first >> ende.second; holeNumber[0] = 1; holeNumber[k] = 1; hole[0][0].first = start.first; hole[0][0].second = start.second; hole[k][0].first = ende.first; hole[k][0].second = ende.second; mini[0][0] = 0; mini[k][0] = 1e15; for (int i = 1; i <= k - 1; ++i) { std::cin >> holeNumber[i]; for (int j = 0; j < holeNumber[i]; ++j) { mini[i][j] = 1e15; std::cin >> hole[i][j].first >> hole[i][j].second; } } if (m == 1) { for (int i = 1; i <= k; ++i) { for (int j = 0; j < holeNumber[i]; ++j) { for (int q = 0; q < holeNumber[i - 1]; ++q) { int val = abss(hole[i][j].first - hole[i - 1][q].first) + abss(hole[i][j].second - hole[i - 1][q].second); mini[i][j] = std::min(mini[i][j], val + mini[i - 1][q]); } } } std::cout << mini[k][0]; return 0; } for (int i = 1; i <= k; ++i) { for (int j = 0; j < holeNumber[i]; ++j) { for (int q = 0; q < holeNumber[i - 1]; ++q) { int val = calc(hole[i][j], hole[i - 1][q], m); // std::cout << val << " " << j << " " << q << "\n"; mini[i][j] = std::min(mini[i][j], val + mini[i - 1][q]); } } } std::cout << mini[k][0]; }

Compilation message (stderr)

obelisk.cpp:56:6: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
 main()
      ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...