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 #776 (Div. 3) A B C D E -> 正文阅读

[C++知识库]Codeforces Round #776 (Div. 3) A B C D E

Codeforces Round #776 (Div. 3) A B C D E

A. Deletions of Two Adjacent Letters

  • Tip: Implementation、String

思路: 签到,稍微提一下思路,目标为一个字符,且原字符串长度为奇数。那么我们只要在原字符串中找到下标是奇数的目标字符,那么我们必定可以通过删除其前面偶数个字符和后面偶数个字符来获得最终的目标字符。由于 S t i n g Sting Sting的下标是从 0 0 0开始的,所以找到 i i i% 2 2 2== 0 0 0即可。

  • 参考代码:
#include<bits/stdc++.h>
using namespace std;
#define mp make_pair
#define int long long 
#define re register int
#define lowbit(x) (x&-x)
#define pb emplace_back
#define cf int t; cin>>t; for(int i=1;i<=t;i++)
#define fer(i,a,b) for(re i = a ; i <= b ; i ++)
#define der(i,a,b) for(re i = a ; i >= b ; i --)
#define snow ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int lcm(int a,int b){return a*b/gcd(a,b);}
typedef pair<int,int>PII;
typedef pair<int,string>PIS;
void solve(){
    string s;
    cin>>s;
    char x;
    cin>>x;
    bool ok=false;
    for(int i=0;i<s.size();i++){
        if(i%2==0&&s[i]==x){//找到了ok变成true
            ok=true;
            break;
        }
    }
    if(ok)cout<<"YES"<<endl;
    else cout<<"NO"<<endl;
}
signed main(){
    cf{
        solve();
    }
    return 0;
}

B. DIV + MOD

  • Tip:math

思路: 难度感觉放在 d i v 3 div3 div3 B B B位置稍大,没做过类似的题可能会忽略一个点。正常思考: 要让 D I V + M O D DIV + MOD DIV+MOD的值尽可能大,那么最好的值应该是 x / a x/a x/a x x x% a a a都处于最大,那么就是 ? r a ? \left\lfloor\dfrac{r}{a}\right\rfloor ?ar?? ? * ? a ? 1 。 a-1。 a?1但是会出现两种情况,1: ? r a ? \left\lfloor\dfrac{r}{a}\right\rfloor ?ar?? ? * ? a ? 1 < l a-1<l a?1<l 那么此时最大值一定在 r r r,因为接下去在 x x x f r o m from from ? r a ? \left\lfloor\dfrac{r}{a}\right\rfloor ?ar?? ? * ? a ? 1 a-1 a?1 ~ r r r的过程中 D I V DIV DIV不变, M O D MOD MOD值却越来越大。2: ? r a ? \left\lfloor\dfrac{r}{a}\right\rfloor ?ar?? ? * ? a ? 1 > = l a-1>=l a?1>=l,那么我们的最大值一定是在 x x x或者 r r r两者中的一个,因为 a a a可以取到 1 1 1或者 2 2 2,这就使得 ? r a ? \left\lfloor\dfrac{r}{a}\right\rfloor ?ar?? ? * ? a ? 1 a-1 a?1是最大值在一定情况下会失效,例如: l = 12 , r = 25 , a = 1 l=12,r=25,a=1 l=12,r=25,a=1 l = 12 , r = 25 , a = 2 l=12,r=25,a=2 l=12,r=25,a=2。显然前者和后者按照 ? r a ? \left\lfloor\dfrac{r}{a}\right\rfloor ?ar?? ? * ? a ? 1 a-1 a?1最终得到的值是 23 23 23 24 24 24。但实则最大都是 25 25 25,所以在包括这种特殊情况的写法可以通过一个 m a x max max来维护。

  • 参考代码:
#include<bits/stdc++.h>
using namespace std;
#define mp make_pair
#define int long long 
#define re register int
#define lowbit(x) (x&-x)
#define pb emplace_back
#define cf int t; cin>>t; for(int i=1;i<=t;i++)
#define fer(i,a,b) for(re i = a ; i <= b ; i ++)
#define der(i,a,b) for(re i = a ; i >= b ; i --)
#define snow ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int lcm(int a,int b){return a*b/gcd(a,b);}
typedef pair<int,int>PII;
typedef pair<int,string>PIS;
void solve(){
    int l,r,a;
    cin>>l>>r>>a;
    int x=r/a;
    x=x*a-1;
    if(x>=l){
        cout<<max(x/a+x%a,r/a+r%a)<<endl;
    }
    else if(x<l){
        cout<<(r/a+r%a)<<endl;
    }
}
signed main(){
    cf{
        solve();
    }
    return 0;
}

C. Weight of the System of Nested Segments

  • Tip:greedy、sortings、implementation

思路: 题意可能会稍微有点难理解,不过感觉也是个大模拟。 n n n的意思是你可以构造 n n n组连线, m m m代表有 m m m个点,我们的任务是在 m m m个点中选取 2 ? n 2*n 2?n个点进行连线,且使得最终连线点的数值和最小同时还要满足 n n n组连线都是大区间包小区间的形式。题目样例中的有序坐标并不是每个点真正的 i d id id,展示给我们的是从小到大排序之后的情形,而真正的 i d id id是通过输入的顺序给予的。所以我们要记录的信息有 i d id id,坐标 s t a r t start start和每个点的价值 v a l val val。 由于题目要求最终总贡献最小,那么我们必定要将最大的 m ? 2 ? n m-2*n m?2?n个点删掉,不能进行连线操作。通过结构体重载操作,将 v a l val val作为关键字排序,先将不可选点删除。再重载,将 s t a r t start start作为关键字排序,接下去设 l = 1 l=1 l=1 r = m r=m r=m进行扫描,一旦遇到删除的点就跳过,最终的 n n n组数据构造的值就是最小且满足大区间包小区间的要求,输出即可。代码已加注释,易于理解。

  • 参考代码:
#include<bits/stdc++.h>
using namespace std;
#define mp make_pair
#define int long long 
#define re register int
#define lowbit(x) (x&-x)
#define pb emplace_back
#define cf int t; cin>>t; for(int i=1;i<=t;i++)
#define fer(i,a,b) for(re i = a ; i <= b ; i ++)
#define der(i,a,b) for(re i = a ; i >= b ; i --)
#define snow ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int lcm(int a,int b){return a*b/gcd(a,b);}
typedef pair<int,int>PII;
typedef pair<int,string>PIS;
const int N=2e5+10;
bool st[N];
struct Node{
    int id,start,val;
    bool operator<(const Node &W)const{
        return start<W.start;
    }
}nodes[N];
struct Node2{
    int id,start,val;
    bool operator<(const Node2 &W)const{
        return val>W.val;
    }
}nodes2[N];
void solve(){
    int n,m;
    cin>>n>>m;
    for(int i=1;i<=m;i++){//所有点都没被删除
        st[i]=false;
    }
    for(int i=1;i<=m;i++){//读入
        nodes[i].id=i;
        cin>>nodes[i].start>>nodes[i].val;
        nodes2[i].id=nodes[i].id;
        nodes2[i].start=nodes[i].start;
        nodes2[i].val=nodes[i].val;
    }
    sort(nodes+1,nodes+1+m);//start作为关键字sort
    sort(nodes2+1,nodes2+1+m);//val作为关键字sort
    int sum=m-n*2;//最大的sum数量个
    for(int i=1;i<=sum;i++){
        st[nodes2[i].id]=true;//删除
    }
    int l=1,r=m;
    vector<PII>S;//存点
    int all=0;//总贡献
    for(int i=1;i<=n;i++){
        while(st[nodes[l].id])l++;//遇到删除的点跳过
        while(st[nodes[r].id])r--;
        S.push_back({nodes[l].id,nodes[r].id});
        all+=nodes[l].val+nodes[r].val;
        l++,r--;
    }
    cout<<all<<endl;
    for(auto x:S){
        cout<<x.first<<' '<<x.second<<endl;
    }
}
signed main(){
    cf{
        solve();
        if(i!=t)cout<<endl;
    }
    return 0;
}

D. Twist the Permutation

  • Tip:math、implementation、constructive algorithms、brute force

思路: 感觉好好把题意看懂,给的例子看懂就是一眼题。给我们的数组是最终的数组,那么我们每次操作只需要将本应该在当前位子上的数复原即可。范围最大 2 e 3 2e3 2e3直接 n 2 n^2 n2暴力可接受。

  • 参考代码:
#include<bits/stdc++.h>
using namespace std;
#define mp make_pair
#define int long long 
#define re register int
#define lowbit(x) (x&-x)
#define pb emplace_back
#define cf int t; cin>>t; for(int i=1;i<=t;i++)
#define fer(i,a,b) for(re i = a ; i <= b ; i ++)
#define der(i,a,b) for(re i = a ; i >= b ; i --)
#define snow ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int lcm(int a,int b){return a*b/gcd(a,b);}
typedef pair<int,int>PII;
typedef pair<int,string>PIS;
const int N=2e3+10;
int a[N];
int b[N];
void solve(){
    int n;
    cin>>n;
    for(int i=1;i<=n;i++){
        cin>>a[i];
    }
    vector<int>cz;
    for(int i=n;i>=1;i--){//将n~1逐步复原,构造。
        int py=i;
        for(int j=1;j<=i;j++){
            if(a[j]==i){
                py=j;
                break;
            }
        }
        int g=py;
        if(py!=i){//py!=i说明有偏移否则没有
            int x=py;
            cz.push_back(x);
            int cnt=0;//用一个b数组将两段连接起来。
            for(int j=g+1;j<=i;j++){//第一段
                b[++cnt]=a[j];
            }
            for(int j=1;j<=g;j++){//第二段
                b[++cnt]=a[j];
            }
            for(int j=1;j<=i;j++){//连接
                a[j]=b[j];
            }
        }
        else cz.push_back(0);
    }
    reverse(cz.begin(),cz.end());//记住要reverse,因为第一个元素是尾巴。
    for(auto x:cz)cout<<x<<' ';
    cout<<endl;
}
signed main(){
    cf{
        solve();
    }
    return 0;
}

E. Rescheduling the Exam

  • Tip:data structures、greedy、implementation

思路: 题意就是将导致考试前休息天数最少的一门考试进行移位,使得最终的所有考试前休息天数的最小值最大。看题意好像不是很难,但其实是一道不太好写的一道题,也算有些难度。首先肯定先找到使得 μ μ μ最小的那门考试的位置,那么将 μ μ μ变大,假设使得 μ μ μ最小的那门考试的位置为 i d x idx idx,使得 μ μ μ变大不但可以移动 i d x idx idx,同样如果 i d x ? 1 > 0 idx-1>0 idx?1>0也可以进行移动使得 μ μ μ发生改变。所以需要考虑两种情况(感觉是一个容易疏忽的点)。接下去我们需要找到怎么放置 i d x idx idx i d x ? 1 idx-1 idx?1这门考试的位置才能使得 μ μ μ尽可能的大。显然,将 i d x idx idx i d x ? 1 idx-1 idx?1取出之后,统计最大的空隙,将其放在最大的空隙处会使得最终的 μ μ μ尽可能趋向最大。同时也要考虑将 i d x idx idx i d x ? 1 idx-1 idx?1放置 d d d处时的情况,那么最终的 μ μ μ必然从 m i n x minx minx(最小空隙)、 m a x ( ( m a x n ? 1 ) / 2 , d ? r u n . b a c k ( ) ? 1 ) max((maxn-1)/2,d-run.back()-1) max((maxn?1)/2,d?run.back()?1)中取一个最小值。最后再考虑 i d x idx idx i d x ? 1 idx-1 idx?1移动情况下最大的 μ μ μ,即为本题答案。

  • 参考代码:
#include<bits/stdc++.h>
using namespace std;
#define mp make_pair
#define int long long 
#define re register int
#define lowbit(x) (x&-x)
#define pb emplace_back
#define cf int t; cin>>t; for(int i=1;i<=t;i++)
#define fer(i,a,b) for(re i = a ; i <= b ; i ++)
#define der(i,a,b) for(re i = a ; i >= b ; i --)
#define snow ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int lcm(int a,int b){return a*b/gcd(a,b);}
typedef pair<int,int>PII;
typedef pair<int,string>PIS;
const int N=2e5+10;
int a[N];
int mi,id;
int n,d;
int check(vector<int>run){
    int maxn=0;
    int minx=1e9;
    fer(i,1,n-1){
        minx=min(minx,run[i]-run[i-1]-1);
        maxn=max(maxn,run[i]-run[i-1]-1);
    }
    return min(minx,max((maxn-1)/2,d-run.back()-1));
}
void solve(){
    cin>>n>>d;
    id=0,mi=d;
    fer(i,1,n){
        cin>>a[i];
        if(a[i]-a[i-1]-1<mi){
            mi=a[i]-a[i-1]-1;
            id=i;
        }
    }
    vector<int>run;
    fer(i,0,n){
        if(i==id)continue;
        run.push_back(a[i]);
    }
    mi=0;
    mi=max(check(run),mi);
    if(id>1){
        run[id-1]=a[id];
        mi=max(mi,check(run));
    }
    cout<<mi<<endl;
}
signed main(){
    cf{
        solve();
    }
    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-03-11 21:57:07  更:2022-03-11 21:57:18 
 
开发: 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/10 16:15:38-

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