首页 > 其他分享 >AtCoder Beginner Contest(abc) 314

AtCoder Beginner Contest(abc) 314

时间:2023-11-02 23:55:18浏览次数:52  
标签:AtCoder abc idx 卡片 int cin 314 dp define




B - Roulette

难度: ⭐

题目大意

有一个猜数字的游戏, 有n个人参加, 每人都猜了若干个数; 最后给出答案数字; 在所有猜中数字的人中输出猜数数量最少的人的编号;(可能不止一个);

解题思路

数据不大, 暴力即可;

神秘代码

#include<bits/stdc++.h>
#define int long long
#define IOS ios::sync_with_stdio(false), cin.tie(0),cout.tie(0)
#define endl '\n'
using namespace std;
const int N = 2e5 + 10, mod = 998244353;
typedef pair<int, int> PII;
int n, m, idx;
int c[N];
set<int> s[N];
vector<int> v;
bool cmp(int a, int b) {
    if (c[a] == c[b]) return a < b;
    return c[a] < c[b];
}
signed main() {
    cin >> n;
    for (int i = 1; i <= n; i++) {
        cin >> c[i];
        for (int j = 1; j <= c[i]; j++) {
            int x;
            cin >> x;
            s[i].insert(x);
        }
    }
    cin >> idx;
    for (int i = 1; i <= n; i++) {
        if (s[i].count(idx)) v.push_back(i);
    }
    if (v.empty()) {
        cout << 0 << endl;
        return 0;
    }
    sort(v.begin(), v.end(), cmp);
    int minn = c[*v.begin()];
    for (int i = 0; i < v.size(); i++) {
        if (c[v[i]] == minn) m++;
        else break;
    }
    cout << m << endl;
    for (int i = 0; i < m; i++) {
        cout << v[i] << " ";
    }
    return 0;
}




C - Rotate Colored Subsequence

难度: ⭐⭐

题目大意

给定一个长度为你的由小写字母组成的字符串; 每个字符都有一个颜色; 我们让同颜色的字符首尾相连地向右移动一位; eg: abcdef的颜色为111233, 操作完之后变成了cabdfe;

解题思路

开一个数组c, c[i]表示下一个颜色为i的字符要替换为c[i]; 我们把每个颜色中最靠前的字符的下标存一下, 最后更新他们即可; 这样就可以线性地更新完所有字符;

神秘代码

#include<bits/stdc++.h>
#define int long long
#define IOS ios::sync_with_stdio(false), cin.tie(0),cout.tie(0)
#define endl '\n'
using namespace std;
const int N = 2e5 + 10, mod = 998244353;
typedef pair<int, int> PII;
int n, m, idx;
int f[N], la[N];
char c[N];
signed main(){
    cin >> n >> m;
    string s;
    cin >> s;
    for (int i = 0; i < n; i++) cin >> f[i];
    for (int i = 0; i < n; i++) {
        if (!c[f[i]]) {
            c[f[i]] = s[i];
            la[f[i]] = i;
        }
        else {
            char x = c[f[i]];
            c[f[i]] = s[i];
            s[i] = x;
        }
    }
    for (int i = 1; i <= m; i++) {
        s[la[i]] = c[i];
    }
    cout << s;
    return 0;
}




D - LOWER

难度: ⭐⭐⭐

题目大意

给定一个由大小写字母组成的字符串; 进行m次操作(t,a,b): 如果t=1, 就把a这个位置的字符换成b; 如果t=2就把所有大写字母变成小写; 如果t=3就把所有小写字母变成大写; 输出最后的字符串;

解题思路

本题的处理难点在于由于数据范围较大, 我们不能每次输入都接着操作, 只能是读取所有操作之后最后进行处理; 这样的难点就是如果我们先t=2, 此时所有字符都是小写字母, 然后在t=1替换一个为一个大写字母; 因为我们最后一直处理一次, 所以这种状态是难以标记的; 所以我们当t=1时, 我们可以记录这次操作是第几个操作, 因为t=2和t=3是相互抵消的, 所以我们只需要记录最后一次last即可; 当t=1的操作顺序在last之后就不需要改变大小写了;

神秘代码

#include<bits/stdc++.h>
#define int long long
#define IOS ios::sync_with_stdio(false), cin.tie(0),cout.tie(0)
#define endl '\n'
using namespace std;
const int N = 5e5 + 10, mod = 998244353;
typedef pair<int, int> PII;
int n, m, idx;
int sp;
int nu[N];
signed main(){
    string s;
    cin >> n >> s;
    s = ' ' + s;
    cin >> m;
    for(int i=1;i<=m;i++) {
        int a, b;
        char c;
        cin >> a >> b >> c;
        if (a == 1) {
            s[b] = c;
            nu[b] = i;
        }
        else if (a == 2) {
            sp = 1;
            idx = i;
        }
        else {
            sp = 2;
            idx = i;
        }
    }
    for (int i = 1; i <= n; i++) {
        if (nu[i] > idx) continue;
        else {
            if (sp == 1 && isupper(s[i])) s[i] += 32;
            if (sp == 2 && islower(s[i])) s[i] -= 32;
        }
    }
    for (int i = 1; i <= n; i++) cout << s[i];
    return 0;
}




E - Roulettes

难度: ⭐⭐⭐⭐

题目大意

现在有n个箱子, 每个箱子都有各自的一个打开费用, 并且每个箱子里都有若干个卡片, 每个卡片都有一个分数; 小莫可以选择花费费用打开一个箱子, 并从中随机选择一个卡片, 然后就可以得到该卡片的分数, 然后把卡片放回箱子里; 问小莫想要得到m分所需要的最小费用期望是多少;

解题思路

初看以为是个概率dp, 然后就一直没找到什么思路, 看完题解后发现思路更像背包dp; 状态表示dp[i]: 表示得到i分数所需要的最小费用期望; 状态转移中我们先遍历分数k, 然后再遍历所有箱子和其里面卡片; 对于当前箱子的卡片, 设某个卡片的分数为x, 那么目前的状态可以用dp[max(0, k-x)]来转移, 我们把所有用于可以转移的dp[max(0, k-x)]求和取平均, 这就是最后用于转移的期望费用sum; 那么什么是可以用于可以转移的dp, 可以想一想, 如果当前箱子里的某张卡片的分数是0, 那么我们就是需要用dp[k-0]也是dp[k]本身, 这是没有意义的; 对于当前这个箱子, 我们拿到有意义卡片(即分数不为0)的概率是num/p[i], num是有意义卡片的数量; 所以我们抽到有意义卡片的期望就是c[i] * p[i] / num, 我们就让sum再加上c[i] * p[i] / num后和dp[k]取min即可;

神秘代码

#include<bits/stdc++.h>
#define int long long
#define IOS ios::sync_with_stdio(false), cin.tie(0),cout.tie(0)
#define endl '\n'
using namespace std;
const int N = 1e2 + 10, mod = 998244353;
typedef pair<int, int> PII;
int n, m, idx;
int s[N][N];
double dp[N];
int p[N], c[N];
signed main(){
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        cin >> c[i] >> p[i];
        for (int j = 1; j <= p[i]; j++) {
            cin >> s[i][j];
        }
    }
    for (int i = 1; i <= m; i++) dp[i] = 1e9;
    for (int k = 1; k <= m; k++) {
        for (int i = 1; i <= n; i++) {
            double x = 0;
            double num = 0;
            for (int j = 1; j <= p[i]; j++) {
                if (s[i][j]) {
                    x += dp[max(0ll, k - s[i][j])];
                    num++;
                }
            }
            x /= num;
            x += c[i] * p[i] / num;
            dp[k] = min(dp[k], x);
        }
    }
    printf("%.30lf",dp[m]);
    return 0;
}




F - A Certain Game

难度: ⭐⭐⭐⭐

标签:AtCoder,abc,idx,卡片,int,cin,314,dp,define
From: https://www.cnblogs.com/mostimali/p/17806708.html

相关文章

  • abc194f O(nk)题解
    前言洛谷唯一的题解似乎是\(O(nk^2)\)的,怎么卡过去的orz这里提供一种与AT官方题解时间复杂度相同的\(O(nk)\)做法。Solution题意很显然,就不解释了。一眼丁真,考虑数位dp。设\(dp_{i,j}\)表示做到第\(i\)位,不同的个数有\(j\)种的方案数。显然有转移方程:\(dp_{i......
  • 2023-2024-1 20231402《计算机基础与程序设计》第六周学习总结
    2023-2024-120231402《计算机基础与程序设计》第六周学习总结作业信息这个作业属于哪个课程2023-2024-1-计算机基础与程序设计这个作业要求在哪里2023-2024-1计算机基础与程序设计第6周作业这个作业的目标自学计算机科学概论第7章《C语言程序设计》第5章作业......
  • [ABC326D] ABC Puzzle 题解
    题意:给定整数\(N\),字符串\(R,C\),构造满足以下条件的\(N\timesN\)矩阵:1.每一行和每一列中\(A,B,C\)各有且仅有一个。2.第\(i\)行的第一个字母等于字符串\(R\)的第\(i\)个字符。3.第\(i\)列的第一个字母等于字符串\(C\)的第\(i\)个字符。看数据范围考虑应该......
  • spring注入bean错误-Bean named 'abc' is expected to be of type 'AAA' but was actu
    先看如下两个注入到spring容器中的bean,一个是UserNewManager,一个是UserManager。@ServicepublicclassUserNewManager{publicvoiddoSomething(){}}@ServicepublicclassUserManager{...}再看下面的testcase,利用@Resource注解来注入bean。@SpringB......
  • AtCoder Beginner Contest 326 F
    F-RobotRotation一句话不开LL,见祖宗感谢大佬,和洛谷上的题解上面已经将的很清楚了,但是如果你跟我一样一开始看不懂他们的代码,那么这篇可能为你解惑点击查看代码#include<bits/stdc++.h>usingnamespacestd;#defineLLlonglong#defineintLL//LL!map<LL,LL>ma;......
  • AtCoder Beginner Contest(abc) 312
    B-TaKCode难度:⭐题目大意题目定义一种矩阵X:该矩阵的是一个长度为9的由黑白色块组成正方形矩阵;该矩阵的左上角和右下角都是一个3*3的黑色矩阵(总共18个),这两个黑色矩阵外面(边缘不算)包围一圈白色色块(总共14个);现在一个n*m的黑白矩阵,问这个大矩阵中有多少......
  • 《AT_abc326_g Unlock Achievement》解题报告
    考场上压根没想到网络流,感觉这题是做过的网络流里算质量比较高的了。首先我们肯定是想直接贪心,但是发现怎么贪心都没办法,而且数据范围非常小,一般数据范围非常小,且贪心不了但又只能贪心的题就用网络流实现。考虑如何建模,首先我们发现权值有正有负,考虑最大权闭合子图,正权值连汇点,......
  • AT_abc326_d ABC Puzzle 题解
    AT_abc326_dABCPuzzle题解看题事实上,即使在\(N=5\)的情况下,也只有\(66240\)个网格满足「每行/每列恰好包含一个A、B和C」。——官方题解其实看到这道题,就感觉是搜索,这很显然。但是我们会发现,最最最native的搜索,是\(4^{5\times5}=2^{50}\)的。感觉不大可过,但是......
  • AT_abc326_e Revenge of "The Salary of AtCoder Inc." 题解
    AT_abc326_eRevengeof"TheSalaryofAtCoderInc."题解一道简单的概率论+动态规划题目(然而我赛时没看这道题题意有一个长度为\(n\)的序列\(A\)、一个\(n\)面骰子,掷若干次骰子,如果这一次掷骰子的点数小于等于上一次的点数,则结束。定义这若干次掷骰子的总的结果为,每次......
  • AT_abc326_f Robot Rotation 题解
    AT_abc326_fRobotRotation题解经典问题,以前遇到过一个类似的问题:[ABC082D]FTRobot。建议对比着看一看这两道题,是两种不同的思路。(那一道题不用输出方案,因此可以用bitset优化;而此题需要输出方案,因此需要双向搜索。思路注意到每次只能「左转」和「左转」。所以,偶数次走......