IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> Codeforces Round #821 (Div. 2) A~D1(模拟、构造) -> 正文阅读

[C++知识库]Codeforces Round #821 (Div. 2) A~D1(模拟、构造)

A. Consecutive Sum

普通的签到题

简而言之就是把每个数的index mod k的余数相同的数字中取最大值,然后不同余数的最大值加起来就可以了

注意取最大值的时候要初始化,以及开long long

#include<bits/stdc++.h>
using namespace std;
#define int long long
int v[104];
signed main()
{
    int t,a;cin>>t;
    while(t--){
        int n,k;int sum=0;cin>>n>>k;
        memset(v,0,sizeof(v));
        for(int i=1;i<=n;i++){cin>>a;v[i%k]=max(v[i%k],a);}
        for(int i=0;i<k;i++)sum+=v[i];
        cout<<sum<<endl;
    }
    return 0;
}

B. Rule of League

题意:一共有n-1场比赛,每个人胜利了x次或者y次,问比赛的每场情况谁赢了

思路:做了一会才发现,因为第一场比赛1和2比,总会有一个人的胜利次数为0所以如果x和y有且只有一个0的时候才会有比赛结果

之后就是硬模拟了

#include<bits/stdc++.h>
using namespace std;
#define int long long
signed main()
{
    int t;cin>>t;int n,a,b;
    while(t--){
        cin>>n>>a>>b;
        if(a==0&&b==0)cout<<"-1\n";
        else if(a==0||b==0){
            if((n-1)%max(a,b)==0){
                    int flag=1;int cou=0;
                    for(int qq=2;qq<=n;qq++){
                        cout<<flag<<" ";cou++;
                        if(cou==max(a,b)){flag=qq+1;cou=0;}
                    }
                    cout<<endl;
            }
            else cout<<"-1\n";
        }
        else cout<<"-1\n";
    }

    return 0;
}

C. Parity Shuffle Sorting

题意:

  • Choose two indices?l and?r?(1≤l<r≤n).
  • If?al+ar?is odd, do?ar:=al. If?al+ar?is even, do?al:=ar.
  • 求最后不下降序列
  • 输出操作的序号(不要求最小步骤)

思路:

1.a[0] 等于 a[n] 或者 a[n] 等于 a[0]

2.若 a[0]+a[i] 是奇数,a[i]=a[0];否则偶数的话,a[i] = a[n-1];

3.记录下答案,之后输出就可以了

(比赛的时候还以为只能是相邻的选择,不过就算读对题了也不一定想到orz)

#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,a[200005],b;
signed main()
{
    int t;cin>>t;
    while(t--){
        int n;cin>>n;
        for(int i=1;i<=n;i++)cin>>a[i];
        vector<pair<int,int>>v;
        if(n==1){cout<<0<<endl;continue;}
        if((a[1]+a[n])%2==1)a[n]=a[1];
        else a[1]=a[n];
        v.push_back({1,n});
        for(int i=2;i<=n-1;i++){
            if((a[1]+a[i])%2==1){a[i]=a[1];v.push_back({1,i});}
            else if((a[n]+a[i])%2==0){a[i]=a[n];v.push_back({i,n});}
        }
        cout<<v.size()<<endl;
        for(int i=0;i<v.size();i++){
            cout<<v[i].first<<" "<<v[i].second<<endl;
        }
    }

    return 0;
}

D1. Zero-One (Easy Version)

题意:

1.给两个01串a和b,字符串长度大于等于5,选择两个在字符串a中的两个字符

2.对这两个字符进行0变1和1变0这两个操作,使得a==b

3.如果这两个字符是相邻的,那么花费x;如果不相邻,那么花费y。(y<x)

4.求最小费用

思路:

1.首先容易看出字符串a如果有奇数个字符和字符串b不一样,那么输出不可能。

2.如果字符串a只有两个相邻的字符和b不一样,那么它有两个操作:1)花费x直接变换。2)花费2*y,两次都和同一个第三个字符变化。这两个操作取最小值就可以。

***3.剩下的其他情况无论怎么样都可以化作用y的方式去做。

( 第3点是比赛的时候我没想到的orz )?

代码:

#include<bits/stdc++.h>
using namespace std;
#define int long long
signed main()
{
    int t;int n,x,y;cin>>t; string a,b;
    while(t--){
        cin>>n>>x>>y;cin>>a>>b;a=" "+a;b=" "+b;
        vector<int>v;int co=0;int sum=0;
        for(int i=1;i<=n;i++){
            if(a[i]!=b[i])co++;
            else if(co!=0){v.push_back(co);sum+=co;co=0;}
        }
        if(co){v.push_back(co);sum+=co;}
        if(sum%2==1)cout<<-1<<endl;
        else if(v.size()==1&&v[0]==2)cout<<min(x,2*y)<<endl;
        else cout<<sum/2*y<<endl;
    }
    return 0;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-21 00:08:17  更:2022-09-21 00:10:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 9:46:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码