码迷,mamicode.com
首页 > 其他好文 > 详细

AtCoder Beginner Contest 161

时间:2020-04-05 15:24:18      阅读:89      评论:0      收藏:0      [点我收藏+]

标签:eve   +=   否则   src   popular   bst   cin   tco   action   

AtCoder Beginner Contest 161

第一次打AtCoder的比赛,因为是日本的网站终于不用倒时差了233。

A - ABC Swap

可以直接按照交换后的顺序输出。

技术图片
#include <bits/stdc++.h>
using namespace std;
int main()
{
    int a,b,c;
    cin>>a>>b>>c;
    cout<<c<< <<a<< <<b;
    return 0;
}
View Code

B - Popular Vote

最后一个测试点会卡取下整的误差,可以通过变换不等式来避免。

技术图片
#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n,m;cin>>n>>m;
    int a[n];for(int &i:a) cin>>i;
    int sum=accumulate(a,a+n,0);
    int cnt=0;
    for(int i:a)
        if(4*m*i>=sum) ++cnt;
    cout<<(cnt>=m?"Yes":"No")<<"\n";
    return 0;
}
View Code

C - Replacing Integer

$N$ 通过不断地减 $K$ 最后一定会在 $[0,K)$ 之内,此时输出 $min(N,K-N)$ 即可。

技术图片
#include <bits/stdc++.h>
using namespace std;
int main()
{
    long long n,k;cin>>n>>k;
    cout<<min(n%k,k-n%k);
    return 0;
}
View Code

D - Lunlun Number

对每个数的最后一位进行广搜,存储每次得到的值,排序输出即可。

技术图片
#include <bits/stdc++.h>
using namespace std;
int main()
{
    queue<long long> q;
    for(long long i=1;i<=9;i++)
        q.push(i);

    vector<long long> ans;
    while(ans.size()<2e5)
    {
        long long n=q.front();
        ans.push_back(n);
        q.pop();

        long long m=n%10;
        
        if(m>0) q.push(n*10+m-1);
        if(m<9) q.push(n*10+m+1);
        q.push(n*10+m);
    }

    sort(ans.begin(),ans.end());
    long long k;cin>>k;
    cout<<ans[k-1];
    
    return 0;
}
View Code

E - Yutori

正反模拟一下,如果至少有一次最终可选择的天数大于 $K$,那么每一天都不是必须工作的,否则取二者的交集。

技术图片
#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n,k,c;cin>>n>>k>>c;
    string s;cin>>s;

    set<int> st1,st2;
    for(int i=0;i<s.size();i++)
    {
        if(s[i]==x) continue;
        st1.insert(i);
        i+=c;
    }
    for(int i=s.size()-1;i>=0;i--)
    {
        if(s[i]==x) continue;
        st2.insert(i);
        i-=c;
    }

    if(st1.size()>k||st2.size()>k) ;
    else{
        for(int i:st1)
            if(st2.count(i)) cout<<i+1<<"\n";
    }

    return 0;
}
View Code

F - Division or Substraction

若 $N$ 最终可以变为 $1$,$K$  需要满足:$\frac{N}{K^n}$${\%K=1}$。

  • 当 $n=0$ 时,$N\%K=1$,此时的 $K$ 为 $N-1$ 的因子。
  • 当 $n>0$ 时,只有枚举不大于 $\sqrt{N}$ 的因子K,才有可能得到 $\frac{N}{K^n}$${\%K=1}$。

最后再讨论一下 $K=1$ 和 $K=N$ 的情况即可。 

技术图片
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
    ll n;cin>>n;

    set<ll> st;
    for(ll i=2;i*i<=n;i++){
        if(n%i==0){
            ll t=n;
            while(t%i==0) t/=i;
            if(t%i==1) st.insert(i);
        }
    }
    for(ll i=1;i*i<=n-1;i++){
        if((n-1)%i==0){
            st.insert(i);
            st.insert((n-1)/i);
        } 
    }
    st.erase(1);
    st.insert(n);

    cout<<st.size()<<"\n";
    
    return 0;
}
View Code

 

AtCoder Beginner Contest 161

标签:eve   +=   否则   src   popular   bst   cin   tco   action   

原文地址:https://www.cnblogs.com/Kanoon/p/12635169.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!