首页 > 其他分享 >AtCoder Beginner Contest 332

AtCoder Beginner Contest 332

时间:2023-12-10 22:24:27浏览次数:42  
标签:AtCoder Beginner int rep cin 332 ans else mod

AtCoder Beginner Contest 332

A - Online Shopping

int main() {
    IOS;
    for (_ = 1; _; --_) {
        cin >> n >> m >> k;
        ll ans = 0;
        rep (i, 1, n) {
            ll a, b; cin >> a >> b;
            ans += a * b;
        }
        ans += (ans >= m ? 0 : k);
        cout << ans;
    }
    return 0;
}

B - Glass and Mug

int main() {
    IOS;
    for (_ = 1; _; --_) {
        cin >> k >> n >> m;
        int a = 0, b = 0;
        rep (i, 1, k) {
            if (a == n) a = 0;
            else if (b == 0) b = m;
            else if (n - a > b) a += b, b = 0;
            else b -= n - a, a = n;
        }
        cout << a << ' ' << b;
    }
    return 0;
}

C - T-shirts

int main() {
    IOS;
    for (_ = 1; _; --_) {
        cin >> n >> m >> s;
        int ans = 0, a = m, b = 0;
        rep (c, 0, n) {
            bool f = 1;
            b = c; a = m;
            rep (i, 0, n - 1) {
                if (s[i] == '0') a = m, b = c;
                else if (s[i] == '1') {
                    if (a > 0) --a;
                    else if (b > 0) --b;
                    else { f = 0; break; }
                } else {
                    if (b > 0) --b;
                    else { f = 0; break; }
                }
            }
            if (f) { ans = c; break; }
        }
        cout << ans;
    }
    return 0;
}

D - Swapping Puzzle

int a[N][N], b[N][N];

int main() {
    IOS;
    for (_ = 1; _; --_) {
        cin >> n >> m;
        rep (i, 0, n - 1) rep (j, 0, m - 1) cin >> a[i][j];
        rep (i, 0, n - 1) rep (j, 0, m - 1) cin >> b[i][j];
        vector<int> x(n), z(m);
        rep (i, 0, n - 1) x[i] = i;
        rep (i, 0, m - 1) z[i] = i;
        int ans = 1e9;
        do {
            vector<int> y = z;
            do {
                bool f = 1;
                rep (i, 0, n - 1) rep (j, 0, m - 1) {
                    if (b[i][j] != a[x[i]][y[j]]) f = 0;
                }
                if (!f) continue;
                vector<int> z = x;
                int cnt = 0;
                rep (i, 0, n - 1) rep (j, i + 1, n - 1) if (z[i] > z[j]) ++cnt;
                z = y;
                rep (i, 0, m - 1) rep (j, i + 1, m - 1) if (z[i] > z[j]) ++cnt;
                ans = min(ans, cnt);
            } while (next_permutation(y.begin(), y.end()));
        } while (next_permutation(x.begin(), x.end()));
        cout << (ans == 1e9 ? -1 : ans);
    }
    return 0;
}

E - Lucky bag

看 t 神代码会的,这里需要一个证明,枚举子集的 dp 复杂度只有 \(3^n\)

一般模板长这样

for (int t = 0; t < 1 << n; ++t)
    for (int u = t; ; u = u - 1 & t) {
        // dp logic
        if (!u) break;
    }
int main() {
    IOS;
    for (_ = 1; _; --_) {
        cin >> n >> m;
        ll s = 0;
        rep (i, 0, n - 1) cin >> a[i], s += a[i];
        double avg = 1.0 * s / m;
        vector<double> cost(1 << n);
        for (int t = 0; t < 1 << n; ++t) {
            int cur = 0;
            rep (i, 0, n - 1) if (t >> i & 1) cur += a[i];
            cost[t] = (cur - avg) * (cur - avg);
        }

        const double inf = 1e30;
        vector<double> d(1 << n, inf); d[0] = 0;
        rep (_, 1, m) {
            vector<double> tmp(1 << n, inf);
            for (int t = 0; t < 1 << n; ++t)
                for (int u = t; ; u = u - 1 & t) {
                    umin(tmp[t], d[u] + cost[u ^ t]);
                    if (!u) break;
                }
            swap(tmp, d);
        }
        cout << precision(12) << d.back() / m;
    }
    return 0;
}

F - Random Update Query

推个式子,用线段树维护就好了,没有区间查询,我就没有写 push up 的逻辑

const int N = 2e5 + 5, mod = 998244353;

int n, m, _, k, cas;
int a[N];

int qpow(int a, int b) {
    int ans = 1;
    for (; b; b >>= 1, a = 1ll * a * a % mod) if (b & 1) ans = 1ll * ans * a % mod;
    return ans;
}

struct BitTree {
    struct node { int l, r, val, tag_k, tag_x; } tr[N << 2];
    void push_down_tag(int rt, int k, int x) {
        if (tr[rt].l == tr[rt].r) {
            tr[rt].val = (1ll * tr[rt].val * k % mod + x) % mod;
        } else {
            tr[rt].tag_x = (1ll * tr[rt].tag_x * k % mod + x) % mod;
            tr[rt].tag_k = 1ll * tr[rt].tag_k * k % mod;
        }
    }
    void push_down(int rt) {
        push_down_tag(rt << 1, tr[rt].tag_k, tr[rt].tag_x);
        push_down_tag(rt << 1 | 1, tr[rt].tag_k, tr[rt].tag_x);
        tr[rt].tag_x = 0, tr[rt].tag_k = 1;
    }
    void build(int rt, int l, int r, int* a) {
        tr[rt] = {l, r, 0, 1, 0};
        if (l == r) { tr[rt].val = a[l]; return; }
        int mid = l + r >> 1;
        build(rt << 1, l, mid, a); build(rt << 1 | 1, mid + 1, r, a);
    }
    void change(int rt, int l, int r, int k, int x) {
        if (r < l) return;
        if (tr[rt].l >= l && tr[rt].r <= r) {
            push_down_tag(rt, k, x);
            return;
        }
        push_down(rt);
        int mid = tr[rt].l + tr[rt].r >> 1;
        if (l <= mid) change(rt << 1, l, r, k, x);
        if (r > mid) change(rt << 1 | 1, l, r, k, x);
    }
    ll ask(int rt, int x) {
        if (tr[rt].l == x && tr[rt].r == x) return tr[rt].val;
        push_down(rt);
        int mid = tr[rt].l + tr[rt].r >> 1;
        if (x <= mid) return ask(rt << 1, x);
        return ask(rt << 1 | 1, x);
    }
} bit;

int main() {
    IOS;
    for (_ = 1; _; --_) {
        cin >> n >> m;
        ll s = 0;
        rep (i, 1, n) cin >> a[i];
        bit.build(1, 1, n, a);
        rep (i, 1, m) {
            int l, r, t; cin >> l >> r >> t;
            int mm = qpow(r - l + 1, mod - 2);
            int x = 1ll * t * mm % mod, k = 1ll * (r - l) * mm % mod;
            bit.change(1, l, r, k, x);
        }
        rep (i, 1, n) cout << bit.ask(1, i) << ' ';
    }
    return 0;
}

标签:AtCoder,Beginner,int,rep,cin,332,ans,else,mod
From: https://www.cnblogs.com/2aptx4869/p/17893354.html

相关文章

  • Atcoder abc301 复盘(更新中)
    跳转比赛链接A-OverallWinner简述:高桥和青木下了\(N\)盘棋。给你一个长度为\(N\)的字符串\(S\),表示这两盘棋的结果。如果\(S\)的\(i\)个字符是t,那么高桥赢得了\(i\)局;如果\(S\)的\(i\)个字符是A,那么青木赢得了这局。高桥和青木之间的胜负关系是谁赢的局......
  • AtCoder Beginner Contest 331 G - Collect Them All【概率期望+容斥+多项式】
    题目链接:ABC331_G写在前面将来如果回顾这道题,建议自己看完题意一定先重新推一遍。如果还是不够熟练,多去做一些同类型的题目吧。题意:盒子里有\(N\)张卡片,每张卡片上写着一个数字,数字的范围是\(1,...,M\),写着数字\(i\)的卡片有\(C_i\)张\((C_i>0)\)。有放回地抽取卡片,每......
  • Daiwa Securities Co. Ltd. Programming Contest 2023(AtCoder Beginner Contest 331)
    DaiwaSecuritiesCo.Ltd.ProgrammingContest2023(AtCoderBeginnerContest331)A-Tomorrow解题思路:模拟。代码:#include<bits/stdc++.h>usingnamespacestd;usingll=longlong;typedefpair<int,int>pii;#definefifirst#definesesecondcons......
  • AtCoder Beginner Contest 331
    A-Tomorrow(abc331A)题目大意给定一年的月数和一月的天数,以及当天日期,问次日的日期。解题思路一个简单的进制加法运算,超出进制数则向前加一。神奇的代码#include<bits/stdc++.h>usingnamespacestd;usingLL=longlong;intmain(void){ios::sync_with_st......
  • AtCoder Beginner Contest 328
    AtCoderBeginnerContest328链接:ToyotaProgrammingContest2023#7(AtCoderBeginnerContest328)-AtCoderA题意:给定n个数,将小于等于x的数加起来输出。#include<bits/stdc++.h>#defineintlonglong#defineendl'\n';usingnamespacestd;voidsolve(){......
  • AtCoder Beginner Contest 331
    AtCoderBeginnerContest331这场状态好差,下午的校赛也打的好差。A-Tomorrow#include<bits/stdc++.h>#defineintlonglong#defineendl'\n'usingnamespacestd;voidsolve(){intM,D;inty,m,d;cin>>M>>D>>y>>m>&......
  • AtCoder Beginner Contest 331 G Collect Them All
    洛谷传送门AtCoder传送门设数字\(i\)第一次拿到的时间为\(t_i\),所求即为\(E(\max\limits_{i=1}^mt_i)\)。施min-max容斥,有:\[\begin{aligned}E(\max\limits_{i=1}^mt_i)&=\sum\limits_{T\subseteq[1,m]\landT\ne\varnothing}(-1)^{|T|-1}E(\min\l......
  • AtCoder Beginner Contest 331
    B-BuyOneCartonofMilk难度:⭐题目大意选择有三种套餐,6个鸡蛋S元,8个鸡蛋M元,12个鸡蛋L元;问如果要买至少N个鸡蛋,最少花费多少钱;解题思路一道入门级dp;神秘代码#include<bits/stdc++.h>#defineintlonglong#defineIOSios::sync_with_stdio(false......
  • AtCoder Beginner Contest 295
    B-Bombs题意:就是说有一种炸弹,能炸曼哈顿距离的障碍物,要你打印出炸完后的图模拟#include<bits/stdc++.h>usingnamespacestd;charmp[50][50];voidsolve(){ intn,m; cin>>n>>m; for(inti=1;i<=n;i++){ for(intj=1;j<=m;j++){ cin>>mp[i][j]; } } for......
  • AtCoder Beginner Contest 326
    B-326-likeNumbers题意:找到一个不小于n的数是326数,定义是思路:简单的模拟循环即可#include<bits/stdc++.h>usingnamespacestd;boolcheck(intx){ vector<int>a; while(x){ a.push_back(x%10); x/=10; } if(a[1]*a[2]==a[0])returntrue; elsereturnfalse;}......