zoukankan      html  css  js  c++  java
  • 2021.01.23 Rating赛 补题&解题报告

    A

    题目大意:给出每位医生的s,d,每位医生只有在si, si + di, si + 2di, ....工作,按顺序访问医生,一天只能访问一位,求访问完所有医生需要多少天

    解题思路:按顺序模拟,先输入医生的总人数,第一个医生的s,d,while循环模拟每一天,如果天数符合,输入下一个医生的s,d,直到所有医生都访问完。

    #include<bits/stdc++.h>
    using namespace std;
    int main()
    {
        int n,sum=0,s,d,t=0;
        cin>>n;
        cin>>s>>d;
        while(1){
            t++;
            if(t>=s&&(t-s)%d==0){
                n--;
                if(n==0){
                    break;
                }
                cin>>s>>d;
            }
        }
        cout<<t<<endl;
        return 0;
    }

    B

    题目大意:给出n个人,开始第一个与第二个打,数大的继续跟下一个打,数小的去队伍后边,直到有人连续赢了k局,输出这个人的值

    解题思路:如果k>=n,则一定打了一圈以上,则输出最大的一个,

    k<n,将所有人放到队列里模拟,找符合条件的那一个

    #include<bits/stdc++.h>
    using namespace std;
    int main()
    {
        long long n,k,i,maxx=-1,a;
        cin>>n>>k;
        queue<long long> q;
        for(i=0; i<n; i++)
        {
            cin>>a;
            q.push(a);
            maxx=max(a,maxx);
        }
        if(n<=k)
        {
            cout<<maxx<<endl;
        }
        else
        {
            long long x,y,x1=0,y1=0;
            x=q.front();
            q.pop();
            y=q.front();
            q.pop();
    
            while(x1<k&&y1<k)
            {
                if(x>y)
                {
                    q.push(y);
                    y=q.front();
                    q.pop();
                    y1=0;
                    x1++;
                }else if(x<y)
                {
                    q.push(x);
                    x=q.front();
                    q.pop();
                    x1=0;
                    y1++;
                }
            }
            if(x1==k)
            {
                cout<<x<<endl;
            }
            if(y1==k)
            {
                cout<<y<<endl;
            }
        }
        return 0;
    }

    C

    位运算的化简

    (呜呜呜比赛的时候就没看懂题目QAQ)

    (位运算理解的不够深入XD)

    参考大佬代码

    #include<bits/stdc++.h>
    using namespace std;
    int main()
    {
        int a,b;
        a = 0,b = 1023;
        int n;
        scanf("%d",&n);
        char s[100];
        int num;
        while(n--)
        {
            scanf("%s%d",s,&num);
            if(s[0] == '|')
            {
                a |= num;
                b |= num;
            }
            else if(s[0] == '&')
            {
                a &= num;
                b &= num;
            }
            else if(s[0] == '^')
            {
                a ^= num;
                b ^= num;
            }
        }
        int num_and = 0,num_or = 0,num_xor = 0;
        num_and = a | b;//0->0,1->1,可以与上b二进制表示中1的部分
        num_or = a & b;//0->1,1->1,两个二进制中都是1的部分
        num_xor = a & (b ^ 1023);//0->1,1->0,两个二进制中都变成1的部分
        printf("3
    ");
        printf("| %d
    ",num_or);
        printf("& %d
    ",num_and);
        printf("^ %d
    ",num_xor);
        return 0;
    }
    View Code
  • 相关阅读:
    mysql配置完半同步复制之后报错[ERROR] The server quit without updating PID file
    mysql配置为半同步复制
    mysql主从复制(半同步方式)
    ssh连接时提示THE AUTHENTICITY OF HOST XX CAN’T BE ESTABLISHED
    Linux 记录所有用户登录和操作的详细日志
    如何禁止某个linux用户访问某些文件夹及执行某些命令
    怎样把linux客户端用户禁止用 su命令来切换用户
    Django---进阶10
    Django---入门
    Django---进阶1
  • 原文地址:https://www.cnblogs.com/a-specter/p/14322772.html
Copyright © 2011-2022 走看看