首页 > 编程语言 >2022牛客寒假算法基础集训营3 签到题7题(附基础集训营1-3签到题总结)

2022牛客寒假算法基础集训营3 签到题7题(附基础集训营1-3签到题总结)

时间:2023-03-25 13:38:12浏览次数:52  
标签:查看 签到 通过 点击 cin 牛客 int maxn 集训营


1、A-智乃的Hello XXXX

  • 签到
#include<bits/stdc++.h>
using namespace std;
int main(){
    cout<<"hello chino\n";
    return 0;
}

2、B-智乃买瓜

  • 背包
#include<bits/stdc++.h>
using namespace std;
const int maxn = 1010, mod = 1e9+7;
int w[maxn], f[maxn][maxn];
int main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int n, m;  cin>>n>>m;
    for(int i = 1; i <= n; i++)cin>>w[i];
    f[0][0] = 1;
    for(int i = 1; i <= n; i++){
        for(int j = 0; j <= m; j++){
            f[i][j] = (f[i][j]+f[i-1][j])%mod;
            if(j+w[i]/2<=m)(f[i][j+w[i]/2]+=f[i-1][j])%=mod;
            if(j+w[i]<=m)(f[i][j+w[i]]+=f[i-1][j])%=mod;
        }
    }
    for(int i = 1; i <= m; i++)cout<<f[n][i]<<" ";
    return 0;
}

3、C-智乃买瓜(another version)

  • 继续dp
#include<bits/stdc++.h>
using namespace std;
const int maxn = 1010, mod = 1e9+7;
int f[maxn];
vector<int>v;
int main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int n;  cin>>n;
    for(int i = 1; i <= n; i++)cin>>f[i];
    f[0] = 1;
    for(int i = 1; i <= n; i++){
        while(f[i]){
            v.push_back(2*i);
            for(int j = 0; j <= n; j++){
                if(j>=i)f[j] = (f[j]-f[j-i]+mod)%mod;
                if(j>=2*i)f[j] = (f[j]-f[j-2*i]+mod)%mod;
            }
        }
    }
    cout<<v.size()<<"\n";
    for(int x : v)cout<<x<<" ";
    return 0;
}

4、D-智乃的01串打乱

  • 随便找一个0和1交换一下位置即可
#include<bits/stdc++.h>
using namespace std;
int main(){
    int n;  string s;
    cin>>n>>s;
    swap(s[s.find('0')],s[s.find('1')]);
    cout<<s;
    return 0;
}

5、E-智乃的数字积木(easy version)

  • 简单贪心策略,对于初始固定的积木顺序,考虑到只有相邻颜色的能够交换,所以对相邻颜色的积木进行一个排序,我们尽可能让相同颜色的积木,数字较大的放在前面即可
  • 1≤N,M≤10^5, 0≤K≤10,发现本题K的数据范围较小,所以可以直接暴力模拟计算答案,然后每次染色后只需修改颜色值然后重新再跑暴力即可。
#include<bits/stdc++.h>
typedef long long LL;
using namespace std;
const int maxn = 1e5+10, mod = 1e9+7;

LL n, m, k;
string s;
int c[maxn];
LL solve(){
    for(int l = 0, r = 0; l < n; r = l){
        while(c[r]==c[r+1])r++; //找到颜色相同的区间
        sort(s.begin()+l, s.begin()+r+1, greater<int>());//对颜色相同的区间进行排序
        l = r+1; //更新遍历范围
    }
    LL ans = 0;
    for(int i = 0; i < n; i++){
        ans = (ans*10+s[i]-'0'+mod)%mod;
    }
    return ans;
}

int main(){
    cin>>n>>m>>k;
    cin>>s;
    for(int i = 0; i < n; i++)cin>>c[i];
    cout<<solve()<<"\n";
    while(k--){
        int x, y;  cin>>x>>y;
        for(int i = 0; i < n; i++){
            if(c[i]==x)c[i] = y;
        }
        cout<<solve()<<"\n";
    }
    return 0;
}

6、I-智乃的密码

  • 题解
#include<bits/stdc++.h>
typedef long long LL;
using namespace std;
const int maxn = 1e5+10;
LL f[maxn][4]; //到第i个位置为止,每种字符上一次出现的位置
int main(){
    LL n, l, r;  cin>>n>>l>>r;
    string s;  cin>>s;  s="0"+s;
    for(int i = 1; i <= n; i++){
        if(isupper(s[i]))s[i]='0';
        else if(islower(s[i]))s[i]='1';
        else if(isdigit(s[i]))s[i]='2';
        else s[i]='3';
        for(int j = 0; j < 4; j++)f[i][j] = f[i-1][j];
        f[i][s[i]-'0']=i;
    }
    LL ans = 0;
    for(int i = l; i <= n; i++){//枚举右端点
        sort(f[i],f[i]+4);
        LL nl = max(i-r+1, 1ll), nr = i-l+1;//左端点的可选范围
        if(f[i][1]>=nl){ //满足3种不同的位置在可选范围内
            ans += min(f[i][1],nr)-nl+1;
        }
    }
    cout<<ans<<"\n";
    return 0;
}

7、L-智乃的数据库

  • 直接模拟就行,对于按照字段分类可以把需要使用的m个字段拿出来重新组成新的vector。
  • 对于聚合统计个数,可以直接map判个重记录一下相同vector的个数即可。
#include<bits/stdc++.h>
typedef long long LL;
using namespace std;
const int maxn = 1010;

string s[maxn];
map<string,int>field;
int a[maxn][maxn];

int main(){
    //输入数据表
    int n, m;  cin>>n>>m;
    for(int i = 1; i <= m; i++)cin>>s[i], field[s[i]] = i;
    for(int i = 1; i <= n; i++){
        for(int j = 1; j <= m; j++)cin>>a[i][j];
    }
    //处理字段
    cin.get();  string ss;  getline(cin,ss);
    vector<int>id;
    int cur = 36;
    for(int i = 37; i<ss.size(); i++){
        if(ss[i]==','||ss[i]==';'){
            string k = ss.substr(cur, i-cur);
            id.push_back(field[k]);
            cur = i+1;
        }
    }
    //输出结果
    map<vector<int>,int> res;
    for(int i = 1; i <= n; i++){
        vector<int>vc;
        for(int x : id){
            vc.push_back(a[i][x]);
        }
        res[vc]++;
    }
    cout<<res.size()<<"\n";
    for(auto x : res)cout<<x.second<<" ";
    return 0;
}

附签到题总结

  • 2022牛客寒假算法基础集训营1
    题号 标题 已通过代码 通过率 我的状态
    A 九小时九个人九扇门 点击查看 1956/3965 未通过
    B 炸鸡块君与FIFA22 点击查看 772/2772 未通过
    C Baby’s first attempt on CPU 点击查看 1402/4353 未通过
    D 牛牛做数论 点击查看 1160/3461 通过(数学结论)
    E 炸鸡块君的高中回忆 点击查看 3459/17851 通过(贪心,结论)
    F 中位数切分 点击查看 2035/3008 通过(数学结论)
    G ACM is all you need 点击查看 265/809 未通过
    H 牛牛看云 点击查看 2499/10363 通过(化简后暴力枚举)
    I B站与各唱各的 点击查看 1133/3199 通过(数学结论)
    J 小朋友做游戏 点击查看 2915/11305 通过(贪心后排序枚举)
    K 冒险公社 点击查看 444/1144 未通过
    L 牛牛学走路 点击查看 3695/5901 通过(输出)
  • 2022牛客寒假算法基础集训营2
    题号 标题 已通过代码 通过率 我的状态
    A 小沙的炉石 点击查看 1096/4595 通过(推导结论)
    B 小沙的魔法 点击查看 294/969 未通过
    C 小沙的杀球 点击查看 3144/10359 通过(贪心)
    D 小沙的涂色 点击查看 100/324 未通过
    E 小沙的长路 点击查看 1534/5205 通过(贪心后结论)
    F 小沙的算数 点击查看 1493/8685 通过(简单模拟)
    G 小沙的身法 点击查看 423/1673 未通过
    H 小沙的数数 点击查看 2005/8364 通过(贪心后结论)
    I 小沙的构造 点击查看 1073/4952 通过(模拟)
    J 小沙的Dota 点击查看 48/235 未通过
    K 小沙的步伐 点击查看 3379/7150 通过(签到)
    L 小沙的remake(普通版) 点击查看 314/1038 未通过
    M 小沙的remake(竞速版) 点击查看 334/975 未通过
  • 2022牛客寒假算法基础集训营3
    题号 标题 已通过代码 通过率 我的状态
    A 智乃的Hello XXXX 点击查看 3307/3598 通过(输出)
    B 智乃买瓜 点击查看 2282/4845 通过(分组背包)
    C 智乃买瓜(another version) 点击查看 816/1705 通过(反向dp)
    D 智乃的01串打乱 点击查看 3106/5342 通过(签到)
    E 智乃的数字积木(easy version) 点击查看 1229/2689 通过(贪心后暴力)
    F 智乃的数字积木(hard version) 点击查看 118/753 未通过
    G 智乃的树旋转(easy version) 点击查看 668/1915 未通过
    H 智乃的树旋转(hard version) 点击查看 210/394 未通过
    I 智乃的密码 点击查看 1316/6137 通过(线性dp)
    J 智乃的C语言模除方程 点击查看 282/1401 未通过
    K 智乃的C语言模除方程(another version) 点击查看 88/326 未通过
    L 智乃的数据库 点击查看 1476/3532 通过(简单stl模拟)


标签:查看,签到,通过,点击,cin,牛客,int,maxn,集训营
From: https://blog.51cto.com/gwj1314/6149347

相关文章

  • 牛客网 E吃货
    链接:https://www.nowcoder.com/acm/contest/105/E来源:牛客网时间限制:C/C++1秒,其他语言2秒空间限制:C/C++32768K,其他语言65536K64bitIO......
  • 【牛客小白月赛69】题解与分析A-F【蛋挞】【玩具】【开题顺序】【旅游】【等腰三角形(
    比赛传送门:https://ac.nowcoder.com/acm/contest/52441感觉整体难度有点偏大。......
  • 牛客小白月赛69 ABCDE
    https://ac.nowcoder.com/acm/contest/52441这场小白我给打的,我愿称之为年度喜剧片A-蛋挞#include<bits/stdc++.h>usingnamespacestd;typedeflonglongLL;type......
  • 牛客14612 string AC自动机 + 树状数组
    传送门题目大意  有T组测试数据,对于每组测试时局有一个n和m,n表示初始拥有的字符串数量,m表示操作数量。紧接着输入n个字符串,再读入m行操作,每行以xstr的形式给出,如果x为......
  • 牛客挑战赛67 B数据结构
    牛客挑战赛67B数据结构你有一个长度为n的字符串,其中包含'0','1','2'三种字符。问字符串中有多少个字串满足'0','1','2'三种字符数量相等。\(1<=n<=3e5\)一开始想了......
  • 牛客练习赛100
    牛客练习赛100B.小红的子序列(dp)题目链接子序列问题一般是dp问题,这里结尾dp状态只有四种,蓝偶,红偶,蓝奇,红奇。对于当前物品,所要做的判断就是加与不加入状态完全相反的背......
  • 牛客项目——说说你是如何实现敏感词过滤的?
    面试官:说说你是如何实现敏感词过滤的?敏感词过滤我采用的是前缀树的数据结构,前缀树又叫字典树、查找树,它的根节点不存储信息,其他的每个节点只存储一个字符,有查找效率高的......
  • 牛客网手撕代码(31-58)
    31.数据累加输出题目实现串行输入数据累加输出,输入端输入8bit数据,每当模块接收到4个输入数据后,输出端输出4个接收到数据的累加结果。输入端和输出端与上下游的交互采......
  • 牛客网手撕代码(1-30)
    1.四选一多路选择器题目制作一个四选一的多路选择器,要求输出定义上为线网类型状态转换:状态序号d011d110d201d300解法input[1:0]d1,d2,d......
  • P9147 签到题
    令\(f_i,g_i\)分别为以\(i\)结尾的最长序列,以\(i\)开始的最长序列,答案为\(\max\{f_i+1,g_i+1,[a_{i-1}+1\leqslanta_{i+1}-1]*(f_{i-1}+1+g_{i+1})\}\)。#include......