結果

問題 No.3116 More and more teleporter
ユーザー rogi52
提出日時 2025-04-19 00:19:34
言語 C++23
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 77 ms / 2,000 ms
コード長 10,198 bytes
コンパイル時間 4,215 ms
コンパイル使用メモリ 295,568 KB
実行使用メモリ 12,704 KB
最終ジャッジ日時 2025-04-19 00:19:40
合計ジャッジ時間 5,523 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 22
権限があれば一括ダウンロードができます

ソースコード

diff #

#line 2 "/Users/korogi/Desktop/cp-cpp/template.hpp"
#include <bits/stdc++.h>
using namespace std;

using i32 = int;
using i64 = long long;
using i128 = __int128;
using u32 = unsigned int;
using u64 = unsigned long long;
using u128 = unsigned __int128;
using f32 = double;
using f64 = long double;
using f128 = __float128;

#define DMP(x) cout << "[" << __LINE__ << "]" << " " << #x << ":" << " " << x << endl;

#define FOR1(n)          for(int _ =  0 , n_ = (n); _ < n_; _++)
#define FOR2(i, n)       for(int i =  0 , n_ = (n); i < n_; i++)
#define FOR3(i, s, t)    for(int i = (s), t_ = (t); i < t_; i++)
#define FOR4(i, s, t, d) for(int i = (s), t_ = (t), d_ = (d); i < t_; i += d_)
#define OVERLOAD4(a, b, c, d, e, ...) e
#define FOR(...) OVERLOAD4(__VA_ARGS__, FOR4, FOR3, FOR2, FOR1)(__VA_ARGS__)

#define REV1(n)          for(int _ = (n) - 1; _ >=  0 ; _--)
#define REV2(i, n)       for(int i = (n) - 1; i >=  0 ; i--)
#define REV3(i, s, t)    for(int i = (t) - 1, s_ = (s); i >= s_; i--)
#define REV4(i, s, t, d) for(int i = (t) - 1, s_ = (s), d_ = (d); i >= s_; i -= d_)
#define OVERLOAD3(a, b, c, d, ...) d
#define REV(...) OVERLOAD4(__VA_ARGS__, REV4, REV3, REV2, REV1)(__VA_ARGS__)

#define FOR_SUBSET(T, S) for(int S_ = (S), T = S_; T >= 0; T = (T == 0 ? -1 : (T - 1) & S_))

#define MULTI for(int testcase_ = in(), testcase = 0; testcase < testcase_; testcase++) [&]

template < class T > using heap_max = priority_queue< T, vector< T >, less< T > >;
template < class T > using heap_min = priority_queue< T, vector< T >, greater< T >>;

template < class T, class U > bool chmin(T& a, const U& b) { return a > b ? a = b, 1 : 0; }
template < class T, class U > bool chmax(T& a, const U& b) { return a < b ? a = b, 1 : 0; }

i64 floor_div(const i64 n, const i64 d) { assert(d != 0); return n / d - ((n ^ d) <  0 && n % d != 0); }
i64  ceil_div(const i64 n, const i64 d) { assert(d != 0); return n / d + ((n ^ d) >= 0 && n % d != 0); }

template < class T, class F > T bin_search(T ok, T ng, F check) { while(abs(ok - ng) > 1) { T mid = (ok + ng) / 2; (check(mid) ? ok : ng) = mid; } return ok; }
template < class T, class F > T bin_search_real(T ok, T ng, F check, int step = 100) { FOR(step) { T mid = (ok + ng) / 2; (check(mid) ? ok : ng) = mid; } return ok; }

template < class T, class U > T accum(const vector< U >& a) { return accumulate(a.begin(), a.end(), T(0)); }
template < class T > pair< T, int > min(const vector< T >& a) { auto itr = min_element(a.begin(), a.end()); return {*itr, itr - a.begin()}; }
template < class T > pair< T, int > max(const vector< T >& a) { auto itr = max_element(a.begin(), a.end()); return {*itr, itr - a.begin()}; }
template < class T > void sort(vector< T >& a) { sort(a.begin(), a.end()); }
template < class T > void rsort(vector< T >& a) { sort(a.rbegin(), a.rend()); }
template < class T > void reverse(vector< T >& a) { reverse(a.begin(), a.end()); }
void sort(string& s) { sort(s.begin(), s.end()); }
void rsort(string& s) { sort(s.rbegin(), s.rend()); }
void reverse(string& s) { reverse(s.begin(), s.end()); }
template < class T, class Cmp > void sort(vector< T >& a, Cmp cmp) { sort(a.begin(), a.end(), cmp); }
template < class T > int LB(vector< T >& a, T x) { return distance(a.begin(), lower_bound(a.begin(), a.end(), x)); }
template < class T > int UB(vector< T >& a, T x) { return distance(a.begin(), upper_bound(a.begin(), a.end(), x)); }
template < class T > void unique(vector< T >& a) { sort(a.begin(), a.end()); a.erase(unique(a.begin(), a.end()), a.end()); }
vector<int> iota(int n) { vector<int> a(n); iota(a.begin(), a.end(), 0); return a; }

istream& operator >> (istream& is, i128& x) {
    string s; is >> s;
    int m = (s[0] == '-');
    x = 0;
    FOR(i, m, ssize(s)) x = x * 10 + (s[i] - '0');
    if(m) x *= -1;
    return is;
}
ostream& operator << (ostream& os, const i128& x) {
    if(x == 0) return os << '0';
    i128 y = x; if(y < 0) { os << '-'; y *= -1; }
    vector<int> ny;
    while(y) ny.push_back(y % 10), y /= 10;
    REV(i, ssize(ny)) os << ny[i];
    return os;
}
namespace scan {
struct x0 { template < class T > operator T() { T x; cin >> x; return x; } };
struct x1 { int n; x1(int n) : n(n) {} template < class T > operator vector< T >() { vector< T > a(n); for(T& x : a) cin >> x; return a; } };
struct x2 { int h, w; x2(int h, int w) : h(h), w(w) {} template < class T > operator vector< vector< T > >() { vector m(h, vector< T >(w)); for(vector< T >& a : m) for(T& x : a) cin >> x; return m; } };
struct cppio { cppio() { cin.tie(0); ios::sync_with_stdio(0); } } cppio_instance;
}
scan::x0 in() { return scan::x0(); }
scan::x1 in(int n) { return scan::x1(n); }
scan::x2 in(int h, int w) { return scan::x2(h, w); }

template < class T > ostream& operator << (ostream& os, const vector< T > a) {
    const int n = a.size();
    FOR(i, n) { os << a[i]; if(i + 1 != n) os << ' '; }
    return os;
}
template < class T > int print_n(const vector< T > a) { for(T x : a) cout << x << '\n'; return 0; }
int print() { cout << '\n'; return 0; }
template < class Head, class... Tail > int print(Head&& h, Tail&&... t) { cout << h; if(sizeof...(Tail)) cout << ' '; return print(forward<Tail>(t)...); }
namespace printer {
    void prec(int n) { cout << fixed << setprecision(n); }
    void flush() { cout.flush(); }
}

constexpr pair<int, int> dir4[] = {{-1, 0}, {0, -1}, {+1, 0}, {0, +1}};

vector<int>& operator ++ (vector<int>& a) { for(auto& e : a) e++; return a; }
vector<int>& operator -- (vector<int>& a) { for(auto& e : a) e--; return a; }
vector<int>  operator ++ (vector<int>& a, int) { vector<int> b = a; ++a; return b; }
vector<int>  operator -- (vector<int>& a, int) { vector<int> b = a; --a; return b; }

template < class T > vector<pair< T, int>> RLE(const vector< T >& a) { vector<pair< T, int>> v; for(const T& x : a) { if(not v.empty() and v.back().first == x) v.back().second++; else v.emplace_back(x, 1); } return v; }
vector<pair<char, int>> RLE(const string& s) { vector<pair<char, int>> v; for(const char& c : s) { if(not v.empty() and v.back().first == c) v.back().second++; else v.emplace_back(c, 1); } return v; }
template < class String, class Same > vector<String> RLE(const String& a, const Same same) { vector<String> v; for(const auto& x : a) { if(not v.empty() and same(v.back().back(), x)) v.back().push_back(x); else v.push_back({x}); } return v; }

int YESNO(bool yes) { return print(yes ? "YES" : "NO"); }
int YesNo(bool yes) { return print(yes ? "Yes" : "No"); }

constexpr i32 INF32 = 1e9;
constexpr i64 INF64 = 1e18;
#line 2 "/Users/korogi/Desktop/cp-cpp/ds/segtree.hpp"

template < class Monoid > struct segtree {
    using M = Monoid;
    using T = typename M::value_type;

    segtree() : segtree(0) {}
    segtree(int n) : segtree(n, M::e()) {}
    segtree(int n, T x) : segtree(vector(n, x)) {}
    segtree(const vector< T >& a_) : n(ssize(a_)) {
        lg = ce2(n);
        sz = 1 << lg;
        a = vector(sz + sz, M::e());
        FOR(i, n) a[sz + i] = a_[i];
        REV(i, 1, sz) update(i);
    }

    // a[i] <- x
    void set(int i, T x) {
        assert(0 <= i and i < n);
        i += sz;
        a[i] = x;
        FOR(p, 1, lg + 1) update(i >> p);
    }
    // a[i]
    T v(int i) {
        assert(0 <= i and i < n);
        return a[i + sz];
    }
    // [l, r)
    T v(int l, int r) {
        assert(0 <= l and l <= r and r <= n);
        T sl = M::e(), sr = M::e();
        for(l += sz, r += sz; l < r; l >>= 1, r >>= 1) {
            if(l & 1) sl = M::op(sl, a[l++]);
            if(r & 1) sr = M::op(a[--r], sr);
        }
        return M::op(sl, sr);
    }
    // [0, n)
    T av() { return a[1]; }

    template < class F > int max_right(int l, F f) {
        assert(0 <= l and l <= n);
        assert(f(M::e()));
        if(l == n) return n;
        l += sz;
        T s = M::e();
        do {
            while(l % 2 == 0) l >>= 1;
            if(not f(M::op(s, a[l]))) {
                while(l < sz) {
                    l = 2 * l;
                    if(f(M::op(s, a[l]))) s = M::op(s, a[l++]);
                }
                return l - sz;
            }
            s = M::op(s, a[l]);
            l++;
        } while((l & -l) != l);
        return n;
    }
    template < class F > int min_left(int r, F f) {
        assert(0 <= r and r <= n);
        assert(f(M::e()));
        if(r == 0) return 0;
        r += sz;
        T s = M::e();
        do {
            r--;
            while(r > 1 and r % 2 == 1) r >>= 1;
            if(not f(M::op(a[r], s))) {
                while(r < sz) {
                    r = 2 * r + 1;
                    if(f(M::op(a[r], s))) s = M::op(a[r--], s);
                }
                return r + 1 - sz;
            }
            s = M::op(a[r], s);
        } while((r & -r) != r);
        return 0;
    }

  private:
    int n, sz, lg;
    vector< T > a;
    int ce2(int n) { int e = 0; while((1 << e) < n) e++; return e; }
    void update(int k) { a[k] = M::op(a[2 * k], a[2 * k + 1]); }
};
#line 2 "/Users/korogi/Desktop/cp-cpp/alg/minmax.hpp"

namespace alg {
template < class T > struct min_m {
    using value_type = T;
    static constexpr T op(const T& a, const T& b) { return min(a, b); }
    static constexpr T e() { return numeric_limits< T >::max(); }
    static constexpr bool comm() { return true; }
};
template < class T > struct max_m {
    using value_type = T;
    static constexpr T op(const T& a, const T& b) { return max(a, b); }
    static constexpr T e() { return numeric_limits< T >::min(); }
    static constexpr bool comm() { return true; }
};
}
#line 4 "a.cpp"

int main() {
    int N = in(), Q = in();
    segtree<alg::min_m<i64>> A(N, INF64), B(N, INF64);
    vector<i64> C(N, INF64);
    C[0] = 0;
    A.set(0, C[0] - 0);
    B.set(0, C[0] + 0);
    FOR(Q) {
        int t = in();
        if(t == 1) {
            int x = in(); x--;
            i64 ans = INF64;
            chmin(ans, A.v(0, x) + x);
            chmin(ans, B.v(x, N) - x);
            print(ans);
        } else {
            int x = in(); i64 c = in(); x--;
            if(chmin(C[x], c)) {
                A.set(x, C[x] - x);
                B.set(x, C[x] + x);
            }
        }
    }
}
0