首页 > 其他分享 >牛客小白月赛55

牛客小白月赛55

时间:2022-11-10 10:44:07浏览次数:48  
标签:ch feb 55 back while 牛客 int 小白月赛 getchar

A 至至子的等差中项

#include<bits/stdc++.h>
using namespace std;

int32_t main(){
    int a , b;
    cin >> a >> b;
    cout << b * 2 - a << "\n";
}

B 至至子的按位与

如果在二进制下按位考虑。如果a,b某位都是1的话c的这一位自然也是1。如果都是0的话,c0,1都可但是尽可能的大所以选择1。如果不相同的情况就只能选择0了。

#include<bits/stdc++.h>
#define int long long
using namespace std;

int read(){
    int x = 0 , f = 1 , ch = getchar();
    while( (ch < '0' || ch > '9') && ch != '-' ) ch = getchar();
    if( ch == '-' ) f = -1 , ch = getchar();
    while( ch >= '0' && ch <= '9' ) x = ( x << 3 ) + ( x << 1 ) + ch - '0' , ch = getchar();
    return x * f;
}

int32_t main(){
    int a = read() , b = read() , c = 0;
    vector<int> v;

    for( int i = 0 ; i < 63 ; i ++ ){
        if( (a&1) == (b&1) ) c += ( 1ll << i );
        a >>= 1 , b >>= 1 ;
    }
    cout << c << "\n";
}

C 至至子的斐波那契

斐波那契第88项就大于1e18了,所以先计算出足够长斐波那契数列,然后对于每个询问二分就好了

#include<bits/stdc++.h>
#define int long long
using namespace std;

int read(){
    int x = 0 , f = 1 , ch = getchar();
    while( (ch < '0' || ch > '9') && ch != '-' ) ch = getchar();
    if( ch == '-' ) f = -1 , ch = getchar();
    while( ch >= '0' && ch <= '9' ) x = ( x << 3 ) + ( x << 1 ) + ch - '0' , ch = getchar();
    return x * f;
}

int32_t main(){
    int n = 2;
    vector<int> feb;
    feb.push_back(0) , feb.push_back(1) ,feb.push_back(1);
    for( ; feb.back() < 1e18 ;  n ++ )
        feb.push_back( feb[n] + feb[n-1] );

    for( int T = read() , x , t ; T ; T -- ){
        x = read();
        t = lower_bound( feb.begin() , feb.end() , x ) - feb.begin();
        if( feb[t] - x >= x - feb[t-1]  ) t --;
        cout << t << "\n";
    }
}

D 至至子的鸿门宴

一共只能取\(\sum_i=1^n(a_i-i)\)个,每次只能取一个。易知取的顺序没有影响,所以一共能取奇数个先手必胜。

#include<bits/stdc++.h>
#define int long long
using namespace std;

int read(){
    int x = 0 , f = 1 , ch = getchar();
    while( (ch < '0' || ch > '9') && ch != '-' ) ch = getchar();
    if( ch == '-' ) f = -1 , ch = getchar();
    while( ch >= '0' && ch <= '9' ) x = ( x << 3 ) + ( x << 1 ) + ch - '0' , ch = getchar();
    return x * f;
}

int32_t main(){
    int sum = 0 , n = read();
    for( int i = 1 , a ; i <= n ; i ++ )
        a = read() - i , sum += a;
    if( sum & 1 ) cout << "ZZZ\n";
    else cout << "SSZ\n";
}

E 至至子的长链剖分

这是一个构造题目,要构造一棵树,每一个点有一个权值,且父节点的权值必须比子节点大,叶子节点权值只能为零。

那么首先我们就要先找到根节点,发现如果根节点不唯一,这无解。

然后我们判断每一个权值为i的节点数如果比i-1少,那么一定无解。

再次基础上,我们按照全职递减的方法连成多个链,把每一条链都插在根节点上就好。

#include<bits/stdc++.h>

using namespace std;


int read() {
    int x = 0, f = 1, ch = getchar();
    while ((ch < '0' || ch > '9') && ch != '-') ch = getchar();
    if (ch == '-') f = -1, ch = getchar();
    while (ch >= '0' && ch <= '9') x = (x << 3) + (x << 1) + ch - '0', ch = getchar();
    return x * f;
}

const int N = 2e5+5;
int fa[N] ;//每个节点的父亲
vector<int> h[N];//每种权值点的集合


void solve(){
    int n = read() , m = -1;
    fill( fa+1 , fa+1+n , 0 );
    fill( h , h+1+n , vector<int>() );
    for( int i = 1 , x ; i <= n ; i ++ )
        x = read() , h[x].push_back(i) , m = max( m , x );
    if( h[m].size() > 1 ){
        cout << "-1\n";
        return;
    }
    for( int i = 2 ; i <= m ; i ++ )
        if( h[i].size() > h[i-1].size() ) {
            cout << "-1\n";
            return;
        }
    int root = h[m][0];
    fa[root] = root , h[m].pop_back();
    while( m >= 0 ){
        while( h[m].empty() ) m --;
        if( m < 0 ) break;
        int f = h[m].back();//链的起点
        fa[f] = root , h[m].pop_back();
        for( int i = m - 1 , t ; i >= 0 ; i -- )//构造链
            t = h[i].back() , h[i].pop_back() , fa[t] = f , f = t;
    }
    cout << root << "\n";
    for( int i = 1 ; i <= n ; i ++ )
        if( fa[i] != i ) cout << fa[i] << " " << i << "\n";
}

int32_t main() {
    for( int T = read() ; T ; T -- )
        solve();
}

标签:ch,feb,55,back,while,牛客,int,小白月赛,getchar
From: https://www.cnblogs.com/PHarr/p/16876308.html

相关文章

  • ed25519加密签名算法及应用
    刷知乎时看到一篇文章,很感兴趣,来学习一下!转载文章:ed25519加密签名算法及应用初次使用Github时都需上传本地的公钥,这时需要提前在本地生成密钥对,使用的是ssh-keygen命令......
  • HDU 1255 覆盖的面积
    ProblemDescription给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. Input输入数据的第一行是一个正整数T(1<=T<=100),代表测试......
  • HDU 3355 Hop — Don’t Walk!
    ProblemDescriptionKERMITTHEFROGisaclassicvideogamewithasimplecontrolandobjectivebutrequiresagooddealofthinking.Youcontrolanani......
  • UVALive 6955 Finding Lines
    ​​点击打开链接​​随机选一条线段然后判断是否满足答案,然后执行一定的次数,基本可以保证正确。#include<cstdio>#include<ctime>#include<cstring>#include<iostream>#inc......
  • 牛客练习赛105
    切蛋糕的贝贝题意:将多边形一个蛋糕切成6份,使得面积之比为1:1:4:5:1:4(顺序可以打乱),只有两种切法,一种是将过外接圆的多边形的对角线,第二种是从多边形的中心和顶点的连线,先......
  • 牛客竞赛数学专题—整数分解与筛法
    题目链接A.青蛙的约会B.SumofConsecutivePrimeNumbersC.PrimeDistanceD. PrimeLandE. X-factorChainsA.青蛙的约会statement:两只......
  • HDU 5591 ZYB's Game
    ProblemDescription withhisclassmatesinhiking:ahostkeepsanumberin  loses,orthehostwilltellalltheplayersthatthenumbernowisbigger......
  • HDU 5586 Sum
    ProblemDescriptionThereisanumbersequence ,youcanselectainterval[l,r]ornot,allthenumbers  willbecome ..Afterthat,thesumofnnumbers......
  • leetcode-1556-easy
    ThousandSeparatorGivenanintegern,addadot(".")asthethousandsseparatorandreturnitinstringformat.Example1:Input:n=987Output:"987"Exa......
  • 牛客java选择题每日打卡Day15
    牛客java选择题每日打卡Day15......