PTA 520 钻石争霸赛

考试周

考试周快到了,对给定的日期(例如“腊八”就对应 8)和倒计时天数(例如电子屏上的“四天之后”就对应 4),自动调整公式里的分母(例如 8/2=4 里面的那个 2)。

输入格式:
输入在一行中给出两个正整数:A 是给定的日期,不超过 30;B 是倒计时天数,不超过 10。

输出格式:
在一行中输出公式 A/X=B,其中 X 是满足等式的数字,输出时保留小数点后 1 位即可。

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

int main(){
    int a,b;
    scanf("%d%d",&a,&b);
    printf("%d/%.1f=%d",a,a*1.0/b,b);
    return 0;
}

真的恭喜你

当别人告诉你自己考了 x 分的时候,你要回答说:“恭喜你考了 x 分!”比如小明告诉你他考了90分,你就用汉语拼音打出来 gong xi ni kao le 90 fen!。

但是如果小明没考好,比如只考了 20 分,你也“恭喜”人家就不对了。这时候你应该安慰他说:“考了 20 分别泄气!”用汉语拼音写出来就是 kao le 20 fen bie xie qi!。

输入格式:
输入在一行里给出一位小朋友的分数。这个分数是一个 0 到 100 之间的整数。

输出格式:
在一行中输出你对这位小朋友说的话。如果人家考到不低于 90 分,就说 gong xi ni kao le X fen!;如果不到 90 分,就说 kao le X fen bie xie qi!。其中 X 是小朋友输入的分数。

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

int main(){
    int a;
    scanf("%d",&a);
    if(a<90){
        printf("kao le %d fen bie xie qi!\n",a);
    }else{
        printf("gong xi ni kao le %d fen!\n",a);
    }
}

平均成绩

给定一所学校学生的体育成绩,请你统计全班的平均成绩和男生、女生的平均成绩。

输入格式:
输入首先在第一行中给出一个正整数 N(≤10000),即全校学生人数。最后 N 行,每行按照格式 性别 成绩 给出一位学生的信息。其中 性别 为 1 表示男生,0 表示女生;成绩 是一个 0 到 100 之间的整数。

输出格式:
在一行中依次输出全班的平均成绩、男生的平均成绩、女生的平均成绩。输出小数点后1位,数字间有一个空格分隔。

注意:如果全是男生或全是女生,则缺少的性别就没有办法计算平均分,相应的位置应该输出一个 X 表示没有。

输入样例 1:

#include<bits/stdc++.h>
using namespace std;
int n,n1,n2,sum1,sum2,a,b;
int main(){
    scanf("%d",&n);
    while(n--){
        scanf("%d%d",&a,&b);
        if(a){
            n1++;
            sum1+=b;
        }else{
            n2++;
            sum2+=b;
        }
    }
    printf("%.1f",(sum1+sum2)*1.0/(n1+n2));
    if(n1)printf(" %.1f",sum1*1.0/n1);
    else printf(" X");
    if(n2)printf(" %.1f",sum2*1.0/n2);
    else printf(" X");
}

古风A+B

给定两个绝对值不超过 109
​​
的整数 A 和 B,计算它们的和 A+B 是非常简单的事,但要将和这个数字按照中国古风从上到下竖着输出,就不是那么简单了吧?

输入格式:
输入在一行中给出 2 个绝对值不超过 10​9
​​
的整数 A 和 B,其间以空格分隔。

输出格式:
将 A+B 数值的每一位从上到下竖着输出。如果是负数,那么负号占第 1 行,其它数字不用输出符号。

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

void print(int n){
    if(n){
        print(n/10);
        printf("%d\n",n%10);
    }
}

int main(){
    int a,b;
    scanf("%d%d",&a,&b);
    a+=b;
    if(a==0){
        printf("0\n");
        return 0;
    }else if(a<0){
        printf("-\n");
        a=0-a;
    }   
    print(a);
    return 0;
}

猜近似数字

甲想好了一个 n 位数字让乙来猜,只要猜的数字位数正确,至多有 1 位与谜底不同,且不同的数字相差不超过 1,就算猜对了。例如谜底是 67,若乙猜 66、68、77、57,就都算对了;猜 167 就不能算对。

输入格式:
输入首先在第一行给出一个不超过 1000 位数的、最高位不是 0 的正整数,是甲给出的谜底。随后若干行,每行给出一个乙猜的数字,都是最高位不是 0 的正整数。直到出现 -1 表示输入结束,这个数字不要做任何处理。题目保证乙至少猜了一次。

输出格式:
对每一个乙猜的数字,如果猜对了就输出 Yes,否则输出 No。

#include<bits/stdc++.h>
using namespace std;
const int MAXN = 1e4+3;
char c[MAXN];
char d[MAXN];//输入长度>1000

bool judge(){
    int cnt = 0,j,i;
    for(i=0;c[i]&&d[i];++i){
        j = abs(c[i]-d[i]);
        if(j==1){
            if(cnt)return false;
            cnt++;
        }else if(j>1)return false;
    }
    if(c[i]==0&&d[i]==0&&cnt<2)return true;
    return false;
}

int main(){
    scanf("%s",c);
    while(scanf("%s",d)){
        if(d[0]=='-')break;
        if(judge())printf("Yes\n");
        else printf("No\n");
    }
    return 0;
}

随机输一次

现要求你编写一个控制赢面的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方意识到你在控制结果,你需要隔 K 次输一次,其中 K 是系统设定的随机数。

输入格式:
输入首先在第一行给出正整数 N(≤10),随后给出 N 个系统产生的不超过 10 的正随机数 K 1 , K 2 , ⋯ , K N { K_1,K_2,⋯,K_N } K1,K2,,KN,数字间以空格分隔。这意味着第 i(i=0,1,⋯,N−1)次输局之后应该隔 K ​ i + 1 K_{​i+1} Ki+1 次再让下一个输局。如果对方出招太多,则随机数按顺序循环使用。例如在样例中,系统产生了 3 个随机数 {2, 4, 1},则你需要:赢 2 次,输 1 次;赢 4 次,输 1 次;赢 1 次,输 1 次;然后再次回到第 1 个随机数,赢 2 次,输 1 次。
之后每行给出对方的一次出招:“ChuiZi”代表“锤子”、“JianDao”代表“剪刀”、“Bu”代表“布”。“End”代表输入结束,这一行不要作为出招处理。输入保证对方至少出了一招。
输出格式:
对每一个输入的出招,按要求输出赢或输局的招式。每招占一行。

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

int main(){
    int n,cnt=0;
    cin>>n;
    int a[10],inx=0;
    for(int i=0;i<n;++i){
        cin>>a[i];
        a[i]++;
    }
    string s;
    while(cin>>s){
        if(s[0]=='E')break;
        cnt++;
        if(s[0]=='C'){
            if(cnt%a[inx]){
                cout<<"Bu\n";
            }else{
                cout<<"JianDao\n";
                inx = (inx+1)%n;
                cnt = 0;
            }
        }else  if(s[0]=='B'){
            if(cnt%a[inx]){
                cout<<"JianDao\n";
            }else{
                cout<<"ChuiZi\n";
                inx = (inx+1)%n;
                cnt = 0;
            }
        }else{
            if(cnt%a[inx]){
                cout<<"ChuiZi\n";
            }else{
                cout<<"Bu\n";
                inx = (inx+1)%n;
                cnt = 0;
            }
        }
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值