This documentation is automatically generated by competitive-verifier/competitive-verifier
// competitive-verifier: PROBLEM https://judge.yosupo.jp/problem/point_set_range_composite
#include "../../template/template.hpp"
#include "../../structure/segment-tree/segment-tree.hpp"
#include "../../structure/class/point-set-range-composite.hpp"
#include "../../math/combinatorics/montgomery-mod-int.hpp"
using mint = modint998244353;
int main() {
int N, Q;
cin >> N >> Q;
vector< Affine< mint > > data(N);
for(auto& d : data) {
mint x, y;
cin >> x >> y;
d = {x, y};
}
auto seg = SegmentTree(PointSetRangeComposite< mint >(), data);
for (int i = 0; i < Q; i++) {
int t;
cin >> t;
if (t == 0) {
int p;
mint a, b;
cin >> p >> a >> b;
seg.set(p, {a, b});
} else {
int l, r;
mint x;
cin >> l >> r >> x;
cout << seg.prod(l, r).eval(x) << "\n";
}
}
}
#line 1 "test/verify/yosupo-point-set-range-composite-3.test.cpp"
// competitive-verifier: PROBLEM https://judge.yosupo.jp/problem/point_set_range_composite
#line 1 "template/template.hpp"
#include <bits/stdc++.h>
#if __has_include(<atcoder/all>)
#include <atcoder/all>
#endif
using namespace std;
using int64 = long long;
const int64 infll = (1LL << 62) - 1;
const int inf = (1 << 30) - 1;
struct IoSetup {
IoSetup() {
cin.tie(nullptr);
ios::sync_with_stdio(false);
cout << fixed << setprecision(10);
cerr << fixed << setprecision(10);
}
} iosetup;
template <typename T1, typename T2>
ostream &operator<<(ostream &os, const pair<T1, T2> &p) {
os << p.first << " " << p.second;
return os;
}
template <typename T1, typename T2>
istream &operator>>(istream &is, pair<T1, T2> &p) {
is >> p.first >> p.second;
return is;
}
template <typename T>
ostream &operator<<(ostream &os, const vector<T> &v) {
for (int i = 0; i < (int)v.size(); i++) {
os << v[i] << (i + 1 != v.size() ? " " : "");
}
return os;
}
template <typename T>
istream &operator>>(istream &is, vector<T> &v) {
for (T &in : v) is >> in;
return is;
}
template <typename T1, typename T2>
inline bool chmax(T1 &a, T2 b) {
return a < b && (a = b, true);
}
template <typename T1, typename T2>
inline bool chmin(T1 &a, T2 b) {
return a > b && (a = b, true);
}
template <typename T = int64>
vector<T> make_v(size_t a) {
return vector<T>(a);
}
template <typename T, typename... Ts>
auto make_v(size_t a, Ts... ts) {
return vector<decltype(make_v<T>(ts...))>(a, make_v<T>(ts...));
}
template <typename T, typename V>
typename enable_if<is_class<T>::value == 0>::type fill_v(T &t, const V &v) {
t = v;
}
template <typename T, typename V>
typename enable_if<is_class<T>::value != 0>::type fill_v(T &t, const V &v) {
for (auto &e : t) fill_v(e, v);
}
template <typename F>
struct FixPoint : F {
explicit FixPoint(F &&f) : F(std::forward<F>(f)) {}
template <typename... Args>
decltype(auto) operator()(Args &&...args) const {
return F::operator()(*this, std::forward<Args>(args)...);
}
};
template <typename F>
inline decltype(auto) MFP(F &&f) {
return FixPoint<F>{std::forward<F>(f)};
}
#line 4 "test/verify/yosupo-point-set-range-composite-3.test.cpp"
#line 2 "structure/class/monoid.hpp"
template <typename S2, typename Op, typename E>
struct LambdaMonoid {
using S = S2;
S op(const S &a, const S &b) const { return _op(a, b); }
S e() const { return _e(); }
LambdaMonoid(Op _op, E _e) : _op(_op), _e(_e) {}
private:
Op _op;
E _e;
};
template <typename Op, typename E>
LambdaMonoid(Op _op, E _e) -> LambdaMonoid<decltype(_e()), Op, E>;
/*
struct Monoid {
using S = ?;
static constexpr S op(const S& a, const S& b) {}
static constexpr S e() {}
};
*/
#line 2 "structure/segment-tree/segment-tree.hpp"
template <typename Monoid>
struct SegmentTree {
using S = typename Monoid::S;
private:
int n, sz;
vector<S> seg;
Monoid m;
public:
SegmentTree() = default;
explicit SegmentTree(Monoid m, int n) : m(m), n(n) {
sz = 1;
while (sz < n) sz <<= 1;
seg.assign(2 * sz, m.e());
}
explicit SegmentTree(Monoid m, const vector<S> &v)
: SegmentTree(m, (int)v.size()) {
build(v);
}
void build(const vector<S> &v) {
assert(n == (int)v.size());
for (int k = 0; k < n; k++) seg[k + sz] = v[k];
for (int k = sz - 1; k > 0; k--) {
seg[k] = m.op(seg[2 * k + 0], seg[2 * k + 1]);
}
}
void set(int k, const S &x) {
k += sz;
seg[k] = x;
while (k >>= 1) {
seg[k] = m.op(seg[2 * k + 0], seg[2 * k + 1]);
}
}
S get(int k) const { return seg[k + sz]; }
S operator[](int k) const { return get(k); }
void apply(int k, const S &x) {
k += sz;
seg[k] = m.op(seg[k], x);
while (k >>= 1) {
seg[k] = m.op(seg[2 * k + 0], seg[2 * k + 1]);
}
}
S prod(int l, int r) const {
if (l >= r) return m.e();
S L = m.e(), R = m.e();
for (l += sz, r += sz; l < r; l >>= 1, r >>= 1) {
if (l & 1) L = m.op(L, seg[l++]);
if (r & 1) R = m.op(seg[--r], R);
}
return m.op(L, R);
}
S all_prod() const { return seg[1]; }
template <typename C>
int find_first(int l, const C &check) const {
if (l >= n) return n;
l += sz;
S sum = m.e();
do {
while ((l & 1) == 0) l >>= 1;
if (check(m.op(sum, seg[l]))) {
while (l < sz) {
l <<= 1;
auto nxt = m.op(sum, seg[l]);
if (not check(nxt)) {
sum = nxt;
l++;
}
}
return l + 1 - sz;
}
sum = m.op(sum, seg[l++]);
} while ((l & -l) != l);
return n;
}
template <typename C>
int find_last(int r, const C &check) const {
if (r <= 0) return -1;
r += sz;
S sum = m.e();
do {
r--;
while (r > 1 and (r & 1)) r >>= 1;
if (check(m.op(seg[r], sum))) {
while (r < sz) {
r = (r << 1) + 1;
auto nxt = m.op(seg[r], sum);
if (not check(nxt)) {
sum = nxt;
r--;
}
}
return r - sz;
}
sum = m.op(seg[r], sum);
} while ((r & -r) != r);
return -1;
}
};
#line 1 "structure/class/affine.hpp"
template <typename T>
struct Affine {
T a, b; // ax+b
Affine() : a(1), b(0) {}
Affine(T a, T b) : a(a), b(b) {}
T eval(T x) const { return a * x + b; }
static constexpr Affine op(const Affine& l, const Affine& r) {
return {l.a * r.a, l.b * r.a + r.b};
}
constexpr bool operator==(const Affine& p) const {
return a == p.a and b == p.b;
}
constexpr bool operator!=(const Affine& p) const {
return a != p.a or b != p.b;
}
};
#line 2 "structure/class/point-set-range-composite.hpp"
template <typename T>
struct PointSetRangeComposite {
using S = Affine<T>;
static constexpr S op(const S& a, const S& b) { return S::op(a, b); }
static constexpr S e() { return S(); }
};
#line 7 "test/verify/yosupo-point-set-range-composite-3.test.cpp"
#line 2 "math/combinatorics/montgomery-mod-int.hpp"
template <uint32_t mod_, bool fast = false>
struct MontgomeryModInt {
private:
using mint = MontgomeryModInt;
using i32 = int32_t;
using i64 = int64_t;
using u32 = uint32_t;
using u64 = uint64_t;
static constexpr u32 get_r() {
u32 ret = mod_;
for (i32 i = 0; i < 4; i++) ret *= 2 - mod_ * ret;
return ret;
}
static constexpr u32 r = get_r();
static constexpr u32 n2 = -u64(mod_) % mod_;
static_assert(r * mod_ == 1, "invalid, r * mod != 1");
static_assert(mod_ < (1 << 30), "invalid, mod >= 2 ^ 30");
static_assert((mod_ & 1) == 1, "invalid, mod % 2 == 0");
u32 x;
public:
MontgomeryModInt() : x{} {}
MontgomeryModInt(const i64 &a)
: x(reduce(u64(fast ? a : (a % mod() + mod())) * n2)) {}
static constexpr u32 reduce(const u64 &b) {
return u32(b >> 32) + mod() - u32((u64(u32(b) * r) * mod()) >> 32);
}
mint &operator+=(const mint &p) {
if (i32(x += p.x - 2 * mod()) < 0) x += 2 * mod();
return *this;
}
mint &operator-=(const mint &p) {
if (i32(x -= p.x) < 0) x += 2 * mod();
return *this;
}
mint &operator*=(const mint &p) {
x = reduce(u64(x) * p.x);
return *this;
}
mint &operator/=(const mint &p) {
*this *= p.inv();
return *this;
}
mint operator-() const { return mint() - *this; }
mint operator+(const mint &p) const { return mint(*this) += p; }
mint operator-(const mint &p) const { return mint(*this) -= p; }
mint operator*(const mint &p) const { return mint(*this) *= p; }
mint operator/(const mint &p) const { return mint(*this) /= p; }
bool operator==(const mint &p) const {
return (x >= mod() ? x - mod() : x) == (p.x >= mod() ? p.x - mod() : p.x);
}
bool operator!=(const mint &p) const {
return (x >= mod() ? x - mod() : x) != (p.x >= mod() ? p.x - mod() : p.x);
}
u32 val() const {
u32 ret = reduce(x);
return ret >= mod() ? ret - mod() : ret;
}
mint pow(u64 n) const {
mint ret(1), mul(*this);
while (n > 0) {
if (n & 1) ret *= mul;
mul *= mul;
n >>= 1;
}
return ret;
}
mint inv() const { return pow(mod() - 2); }
friend ostream &operator<<(ostream &os, const mint &p) {
return os << p.val();
}
friend istream &operator>>(istream &is, mint &a) {
i64 t;
is >> t;
a = mint(t);
return is;
}
static constexpr u32 mod() { return mod_; }
};
template <uint32_t mod>
using modint = MontgomeryModInt<mod>;
using modint998244353 = modint<998244353>;
using modint1000000007 = modint<1000000007>;
#line 9 "test/verify/yosupo-point-set-range-composite-3.test.cpp"
using mint = modint998244353;
int main() {
int N, Q;
cin >> N >> Q;
vector< Affine< mint > > data(N);
for(auto& d : data) {
mint x, y;
cin >> x >> y;
d = {x, y};
}
auto seg = SegmentTree(PointSetRangeComposite< mint >(), data);
for (int i = 0; i < Q; i++) {
int t;
cin >> t;
if (t == 0) {
int p;
mint a, b;
cin >> p >> a >> b;
seg.set(p, {a, b});
} else {
int l, r;
mint x;
cin >> l >> r >> x;
cout << seg.prod(l, r).eval(x) << "\n";
}
}
}
Env | Name | Status | Elapsed | Memory |
---|---|---|---|---|
g++ | example_00 |
![]() |
6 ms | 3 MB |
g++ | max_random_00 |
![]() |
242 ms | 15 MB |
g++ | max_random_01 |
![]() |
243 ms | 15 MB |
g++ | max_random_02 |
![]() |
247 ms | 15 MB |
g++ | max_random_03 |
![]() |
254 ms | 15 MB |
g++ | max_random_04 |
![]() |
244 ms | 15 MB |
g++ | random_00 |
![]() |
198 ms | 14 MB |
g++ | random_01 |
![]() |
207 ms | 15 MB |
g++ | random_02 |
![]() |
137 ms | 5 MB |
g++ | random_03 |
![]() |
64 ms | 15 MB |
g++ | random_04 |
![]() |
73 ms | 14 MB |
g++ | small_00 |
![]() |
5 ms | 3 MB |
g++ | small_01 |
![]() |
5 ms | 3 MB |
g++ | small_02 |
![]() |
5 ms | 3 MB |
g++ | small_03 |
![]() |
5 ms | 3 MB |
g++ | small_04 |
![]() |
5 ms | 3 MB |
clang++ | example_00 |
![]() |
6 ms | 3 MB |
clang++ | max_random_00 |
![]() |
258 ms | 15 MB |
clang++ | max_random_01 |
![]() |
258 ms | 15 MB |
clang++ | max_random_02 |
![]() |
260 ms | 15 MB |
clang++ | max_random_03 |
![]() |
259 ms | 15 MB |
clang++ | max_random_04 |
![]() |
261 ms | 15 MB |
clang++ | random_00 |
![]() |
213 ms | 15 MB |
clang++ | random_01 |
![]() |
224 ms | 15 MB |
clang++ | random_02 |
![]() |
168 ms | 5 MB |
clang++ | random_03 |
![]() |
66 ms | 15 MB |
clang++ | random_04 |
![]() |
77 ms | 14 MB |
clang++ | small_00 |
![]() |
6 ms | 3 MB |
clang++ | small_01 |
![]() |
5 ms | 3 MB |
clang++ | small_02 |
![]() |
5 ms | 3 MB |
clang++ | small_03 |
![]() |
5 ms | 3 MB |
clang++ | small_04 |
![]() |
5 ms | 3 MB |