Submission #572379

#TimeUsernameProblemLanguageResultExecution timeMemory
572379CpDark이상한 기계 (APIO19_strange_device)C++14
65 / 100
459 ms34628 KiB
#include <bits/stdc++.h> #define fastInput ios::sync_with_stdio(false); cin.tie(nullptr); using namespace std; typedef long long ll; typedef vector<int> vi; typedef vector<vi> vvi; typedef vector<ll> vll; typedef vector<vll> vvll; typedef pair<ll, ll> pii; typedef vector<pii> vp; typedef vector<bool> vb; typedef vector<vb> vvb; ll A, B; inline pii getTime(ll t) { ll x = (t + (t / B)) % A; ll y = t % B; return { x,y }; } inline void pushTime(pii p, ll mod, vp &points) { if (p.first % mod <= p.second % mod) { points.push_back({ p.first % mod, p.second % mod }); } else { points.push_back({ p.first % mod, mod - 1 }); points.push_back({ 0, p.second % mod }); } } ll gcd(ll a, ll b) { if (b == 0) { return a; } else { return gcd(b, a % b); } } const ll inf = 1e18 + 1; int main() { fastInput; int n; cin >> n >> A >> B; ll mod = inf; A /= gcd(A, B + 1); if (A <= inf / B) { mod = A * B; } vp times(n); vp points; ll l, r; for (int i = 0; i < n; i++) { cin >> l >> r; times[i] = { l,r}; if (l - r + 1 >= mod) { cout << mod; return 0; } pushTime(times[i], mod, points); } sort(points.begin(), points.end()); ll count = 0; ll last = points[0].second; ll start = points[0].first; for (int i = 1; i < points.size(); i++) { if (points[i].first > last) { ll amount = last - start + 1; start = points[i].first; count += amount; } last = max(last, points[i].second); } ll amount = last - start + 1; count += amount; cout << count; return 0; }

Compilation message (stderr)

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