Submission #934698

# Submission time Handle Problem Language Result Execution time Memory
934698 2024-02-27T20:05:51 Z haxorman Strange Device (APIO19_strange_device) C++14
Compilation error
0 ms 0 KB
#include <bits/stdc++.h>
using namespace std;

#define int long long

const int mxN = 1e6 + 7;

int32_t main() {
    ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
    
    int n, a, b;
    cin >> n >> a >> b;

    __int128 p = a;
    p *= b;
    p /= gcd(a, b+1);
    
    int ans = 0;
    vector<pair<int,int>> ranges;
    for (int i = 0; i < n; ++i) {
        int l, r;
        cin >> l >> r;

        if (r - l + 1 >= p) {
            ans = p;
        }
        

        if (r < l) {
            ranges.push_back({l, p-1});
            ranges.push_back({0, r});
        }
        else {
            ranges.push_back({l, r});
        }
    }

    if (ans == p) {
        cout << ans << "\n";
        exit(0);
    }
    sort(ranges.begin(), ranges.end());
    
    auto [l, r] = ranges[0];
    for (int i = 1; i < ranges.size(); ++i) {
        auto [lb, rb] = ranges[i];
        
        if (lb <= r) {
            rb = r;
        }
        else {
            ans += r - l + 1;
            l = lb, r = rb;
        }
    }
    ans += r - l + 1;
    cout << ans << "\n";
}

Compilation message

strange_device.cpp: In function 'int32_t main()':
strange_device.cpp:16:10: error: 'gcd' was not declared in this scope
   16 |     p /= gcd(a, b+1);
      |          ^~~
strange_device.cpp:44:10: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17'
   44 |     auto [l, r] = ranges[0];
      |          ^
strange_device.cpp:45:23: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   45 |     for (int i = 1; i < ranges.size(); ++i) {
      |                     ~~^~~~~~~~~~~~~~~
strange_device.cpp:46:14: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17'
   46 |         auto [lb, rb] = ranges[i];
      |              ^