首页 > 其他分享 >Educational Codeforces Round 109 (Rated for Div. 2)

Educational Codeforces Round 109 (Rated for Div. 2)

时间:2023-08-17 19:23:47浏览次数:54  
标签:Educational Rated ve int double typedef long Codeforces define

Educational Codeforces Round 109 (Rated for Div. 2)

A - Potion-making

思路:求最小操作数即药水最简比

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=3e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void init(){

}
void solve(){
    int x,y;cin>>x;
    y=100-x;
    int d=gcd(x,y);
    x/=d,y/=d;
    cout<<x+y<<'\n';
    return;
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int t=1;
    cin>>t;
    init();
    while(t--){
        solve();
    }
    return 0;
}
View Code

 

B - Permutation Sort

思路:可以选连续n-1个任意排序;已经是有序的操作为0

当1在第n个位置,n在第1个位置时:操作3次;

当1已经在第1位置或n已经在第n个位置时,且还有逆序的:操作1次

其他情况需要2次

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=3e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void init(){

}
void solve(){
    int n;cin>>n;
    bool ok=false;
    vector<int>ve(n);
    for(int i=0;i<n;++i){
        cin>>ve[i];
        if(i==0&&ve[i]==1)ok=true;
        if(i==n-1&&ve[i]==n)ok=true;
    }
    vector<int>s=ve;
    sort(s.begin(),s.end());
    int ans=0;
    for(int i=0;i<s.size();++i){
        if(s[i]!=ve[i]){
            ans=2;break;
        }
    }
    if(ans&&ok)ans=1;
    if(ans==2&&ve[0]==n&&ve[n-1]==1)ans=3;
    cout<<ans<<'\n';
    return;
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int t=1;
    cin>>t;
    init();
    while(t--){
        solve();
    }
    return 0;
}
View Code

 

C - Robot Collisions

思路:可以发现分别在奇数和偶数位置的机器会撞在一起,那么将所有机器按奇偶位置分开

有4种爆炸的情况:1. l1→ ←l2 ,t =(l2-l1)/2

          2. ←l1 ←l2 ,t =(l1+l2)/2

          3. l1→ l2→ ,t =(2m-l1-l2)/2

          4. ←l1 l2→ ,t =(m+l1-l2)/2

将所有位置排序后,从前开始遍历,→会与下一个←碰撞,可以用栈放每个→;碰到一个←,即取出栈顶计算爆炸时间,若栈为空的,将←放进栈;←会与下一个←碰撞,栈顶为←时同样计算爆炸时间。

当遍历完之后,栈不为空时,从栈顶开始取,每次取的两个会碰撞;若栈中还剩一个,即为不会爆炸

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=3e5+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;

void init(){

}

map<int,int>mp,op;
int n,m;

void P(vector<int>ve){
    stack<int>stk;
    for(int i=0;i<ve.size();i++){
        if(op[ve[i]]==1)stk.push(ve[i]);
        else{
            if(!stk.empty()){
                int s;
                if(op[stk.top()]==1)s=(ve[i]-stk.top())/2;
                else s=(ve[i]+stk.top())/2;
                mp[stk.top()]=s,mp[ve[i]]=s;
                stk.pop();
            }else stk.push(ve[i]);
        }
    }
    if(!stk.empty()){
        int k=stk.size()/2;
        for(int i=1;i<=k;++i){
            int a=stk.top();stk.pop();
            int s;
            if(op[stk.top()]==1)s=(2*m-a-stk.top())/2;
            else s=(2*m+stk.top()-a)/2;
            mp[stk.top()]=mp[a]=s;
            stk.pop();
        }
        if(!stk.empty()){
            mp[stk.top()]=-1;
            stk.pop();
        }
    }
}
void solve(){
    mp.clear(),op.clear();
    cin>>n>>m;
    vector<int>ve(n+1);
    vector<int>ve1,ve2;
    for(int i=1;i<=n;++i){
        cin>>ve[i];
        if(ve[i]%2)ve1.push_back(ve[i]);
        else ve2.push_back(ve[i]);
    }
    sort(ve1.begin(),ve1.end());
    sort(ve2.begin(),ve2.end());
    for(int i=1;i<=n;++i){
        char c;cin>>c;
        if(c=='R')op[ve[i]]=1;
        else op[ve[i]]=2;
    }
    P(ve1);P(ve2);
    for(int i=1;i<=n;++i){
        cout<<mp[ve[i]]<<' ';
    }cout<<'\n';
    return;
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int t=1;
    cin>>t;
    init();
    while(t--){
        solve();
    }
    return 0;
}
View Code

 

D - Armchairs

思路:f[i][j]表示前i个有人的座位,前j个无人的座位已换好需要的最小移动数;

f[i][j]=min(f[i-1][j],f[i-1][j-1]+abs(p1[i]-p0[j]))分别表示第i个人不坐和坐第j个空位

#include<bits/stdc++.h>
using namespace std;
#define int long long
//#define int __int128
#define double long double
typedef pair<int,int>PII;
typedef pair<string,int>PSI;
typedef pair<string,string>PSS;
const int N=200+5,INF=0x3f3f3f3f,Mod=1e9+7,mod=998244353;
const double eps=1e-6;


void solve(){
    int n;cin>>n;
    vector<int>p1,p0;
    p1.push_back(0),p0.push_back(0);
    for(int i=1,x;i<=n;++i){
        cin>>x;
        if(x==1)p1.push_back(i);
        else p0.push_back(i);
    }
    vector<vector<int>>f(p1.size(),vector<int>(p0.size(),0));
    for(int i=1;i<p1.size();++i)
        for(int j=i;j<p0.size();++j){
            if(i==j)f[i][j]=f[i-1][j-1]+abs(p1[i]-p0[j]);
            else f[i][j]=min(f[i][j-1],f[i-1][j-1]+abs(p1[i]-p0[j]));
        }
    cout<<f[p1.size()-1][p0.size()-1];
    return;
}
signed main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int t=1;
    //cin>>t;
    while(t--){
        solve();
    }
    return 0;
}
View Code

 

标签:Educational,Rated,ve,int,double,typedef,long,Codeforces,define
From: https://www.cnblogs.com/bible-/p/17637492.html

相关文章

  • Codeforces Round 883 (Div. 3)
    比赛链接:https://codeforces.com/contest/1846A.RudolphandCuttheRope题意:给n条绳子,知道一端所在高度坐标和各自绳长,他们另一端都连到一个糖果上,问至少剪掉多少绳子糖果能碰到地面思路:显然只有坐标小于绳长的才能让糖果触地,去掉其他的即可B.RudolphandTic-Tac-Toe题......
  • Codeforces Round 892 (Div. 2)
    CodeforcesRound892(Div.2)目录CodeforcesRound892(Div.2)AUnitedWeStandBOlyaandGamewithArraysCAnotherPermutationProblemDAndreyandEscapefromCapygradEMaximumMonogonosityAUnitedWeStand给定长度为\(n\)的数组a,可以将a中元素添加到空数组b......
  • 2023.08.12 codeforces round 893 div2
    年轻人的第四场div2rank:8217solved:2ratingchange:+31newrating:1354A.Buttons题意:给定a,b,c三种按钮的数量,a按钮只能被Anna按,b按钮只能被Katie按,两个人都可以按c按钮,最后没有按钮可以按的人输,Anna先手,问谁是赢家;两个人肯定优先按c按钮,且Anna是先手,只需比较两人能按的按......
  • Codeforces Round 891 (Div. 3)
    比赛链接:https://codeforces.com/contest/1857A.ArrayColoring题意:一个数列,问能否分成两个和的奇偶性相同的集合思路:因为偶数不改变奇偶性,咱们就统计奇数的个数,能平分成两组就行B.MaximumRounding题意:给一个数,每次可以找一位数不四舍可五入,然后把这个位及后面的数都变成......
  • Educational Codeforces Round 107 (Rated for Div. 2)
    EducationalCodeforcesRound107(RatedforDiv.2)A-ReviewSite思路:数1和3的个数#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong//#defineint__int128#definedoublelongdoubletypedefpair<int,int>PII;typedefpair&l......
  • Codeforces Round 765 (Div. 2) A-E
    A.AncientCivilization好像就是对每个二进制位看一下0多还是1多,选择多的那个数就好了。vp的时候直接猜的,交了一发直接过了voidsolve(){intn=read(),m=read();vector<int>cnt0(m+1),cnt1(m+1);for(inti=1;i<=n;i++){intx=read();for(int......
  • Codeforces Round 893(div2)
    CodeforcesRound893(div2)[A题传送门](Problem-A-Codeforces)A题意:我们有a+b+c个瓶盖,选手1可以拿指定的a个或者c个里面的一个,选手2可以拿指定的b个或者c个里面的一个,可以拿完最后一个的即为获胜者,每个人都有最优策略。A思路:这个题一开始想错了,主要是没有读懂题意,理解清楚......
  • Codeforces Round 892 (Div. 2)
    CodeforcesRound892(Div.2)A.UnitedWeStand简述题意给定一个长度为$n$的数列$a$,要求将$a$的每个元素分配到数列$b$,$c$中,满足以下两个要求$b,c$不为空,即$l_b\geq1,l_c\geq1$。对于任意$i$和$j$$(1\leqi\leql_b,1\leq......
  • Codeforces Global Round 15
    CodeforcesGlobalRound15A-SubsequencePermutation思路:找出原串与排序后的串不同的个数#include<bits/stdc++.h>usingnamespacestd;voidsolve(){intn;cin>>n;strings;cin>>s;stringt=s;sort(t.begin(),t.end());intans=0;......
  • Codeforces Round 892 (Div. 2) A-E
    A.UnitedWeStand题意:给出一个长为\(n\)的数组\(a\),将其中的元素分别放到空数组\(b\)和\(c\)中,使得\(c\)中的任意一个元素都不是\(b\)中任意一个元素的因数,并且两个数组都不是空数组Solution把\(a\)中最小的数放到\(b\),其它的都放到\(c\),一定可以保证要求成立voidsolve(){......