2020年MOOCC语言程序设计精髓第十二周编程题练兵

1大奖赛现场统分
题目内容:
已知某大奖赛有n个选手参赛,m(m>2)个评委为参赛选手评分(最高10分,最低0分)。统分规则为:在每个选手的m个得分中,去掉一个最高分和一个最低分后,取平均分作为该选手的最后得分。要求编程实现:
(1)根据n个选手的最后得分,从高到低输出选手的得分名次表,以确定获奖名单;
(2)根据各选手的最后得分与各评委给该选手所评分数的差距,对每个评委评分的准确性和评分水准给出一个定量的评价,从高到低输出各评委得分的名次表。

提示:首先设计如下5个数组:
(1)sh[i],存放第i个选手的编号;
(2)sf[i],存放第i个选手的最后得分,即去掉一个最高分和一个最低分以后的平均分;
(3)ph[j],存放第j个评委的编号;
(4)f[i][j],存放第j个评委给第i个选手的评分;
(5)pf[j],存放代表第j个评委评分水准的得分。
解决本问题的关键在于计算选手的最后得分和评委的得分。
先计算选手的最后得分。外层循环控制参赛选手的编号i从1变化到n,当第i个选手上场时,输入该选手的编号sh[i]。内层循环控制给选手评分的评委的编号j从1变化到m,依次输入第j个评委给第i个选手的评分f[i][j],并将其累加到sf[i]中,同时求出最高分max和最低分min。当第i个选手的m个得分全部输入并累加完毕后,去掉一个最高分max,去掉一个最低分min,于是第i个选手的最后得分为:
sf[i] = (sf[i] – max – min)/(m-2);
当n个参赛选手的最后得分sf[0],sf[1],…,sf[n]全部计算完毕后,再将其从高到低排序,打印参赛选手的名次表。
下面计算评委的得分。评委给选手评分存在误差,即f[i][j]≠sf[i]是正常的,也是允许的。但如果某个评委给每个选手的评分与各选手的最后得分都相差太大,则说明该评委的评分有失水准。可用下面的公式来对各个评委的评分水平进行定量评价:
在这里插入图片描述2020年MOOCC语言程序设计精髓第十二周编程题练兵_第1张图片

#include 
#include 

void sorting(float score[],int number[],int n){
    int i,j,num;
    float t;
    for(i=0;i<n-1;i++){
        for(j=n-1;j>i;j--){
            if(score[j]>score[j-1]){
                t=score[j];
                score[j]=score[j-1];
                score[j-1]=t;
                num=number[j];
                number[j]=number[j-1];
                number[j-1]=num;
            }
        }
    }
}

int main(){
    int i,j,n,m,max,min;
    printf("How many Athletes?\n");
    scanf("%d",&n);
    int *sh,*ph;
    float *pf,*sf,*f;
    sh=(int *)calloc(n,sizeof(int));
    sf=(float *)calloc(n,sizeof(float));
    printf("How many judges?\n");
    scanf("%d",&m);
    ph=(int *)calloc(m,sizeof(int));
    pf=(float *)calloc(m,sizeof(float));
    f=(float *)calloc(m*n,sizeof(float));
    printf("Scores of Athletes:\n");
    for(i=0;i<n;i++){
        printf("Athlete %d is playing.\n",i+1);
        printf("Please enter his number code:\n");
        scanf("%d",&sh[i]);
        max=min=0;
        for(j=0;j<m;j++){
            printf("Judge %d gives score:\n",j+1);
            scanf("%f",&f[i*m+j]);
            sf[i]+=f[i*m+j];
            if(f[i*m+j]>f[i*m+max])
                max=j;
            if(f[i*m+j]<f[i*m+min])
                min=j;
        }
        printf("Delete a maximum score:%.1f\n",f[i*m+max]);
        printf("Delete a minimum score:%.1f\n",f[i*m+min]);
        sf[i]-=f[i*m+max];
        sf[i]-=f[i*m+min];
        sf[i]=sf[i]/(float)(m-2);
        printf("The final score of Athlete %d is %.3f\n",sh[i],sf[i]);
    }
    //The level of the judges
    for(j=0;j<m;j++){
        ph[j]=j+1;
        for(i=0;i<n;i++){
            pf[j]+=pow((f[i*m+j]-sf[i]),2);
        }
        pf[j]=10.0-sqrt(pf[j]/(float)n);
    }
    //Athletes
    printf("Order of Athletes:\n");
    printf("order\tfinal score\tnumber code\n");
    sorting(sf,sh,n);
    for(i=0;i<n;i++){
        printf("%5d\t%11.3f\t%6d\n",i+1,sf[i],sh[i]);
    }
    sorting(pf,ph,m);
    printf("Order of judges:\n");
    printf("order\tfinal score\tnumber code\n");
    for(j=0;j<m;j++){
        printf("%5d\t%11.3f\t%6d\n",j+1,pf[j],ph[j]);
    }
    printf("Over!Thank you!\n");
    return 0;
}

3单词接龙
题目内容:
阿泰和女友小菲用英语短信玩单词接龙游戏。一人先写一个英文单词,然后另一个人回复一个英文单词,要求回复单词的开头有若干个字母和上一个人所写单词的结尾若干个字母相同,重合部分的长度不限。(如阿泰输入happy,小菲可以回复python,重合部分为py。)现在,小菲刚刚回复了阿泰一个单词,阿泰想知道这个单词与自己发过去的单词的重合部分是什么。他们两人都是喜欢写长单词的英语大神,阿泰觉得用肉眼找重合部分实在是太难了,所以请你编写程序来帮他找出重合部分。
程序运行结果示例1:
happy↙
pythen↙
py

程序运行结果示例2:
sun↙
unknown↙
un
输入格式: “%s%s”
输出格式: “%s\n”

#include 
#include 
#define MAX 20

int main(){
    int i,j,k=0,len1,len2;
    char word1[MAX],word2[MAX],common[MAX];
    scanf("%s%s",word1,word2);
    len1=strlen(word1);
    len2=strlen(word2);
    for(i=0;i<len1;i++){
        for(j=0;j<len2;j++)
            if(word2[j]==word1[i]&&word2[j+1]==word1[i+1]){
                while(word2[j]==word1[i+j]){
                    common[k++]=word2[j];
                    j++;
                }
                common[j]='\0';
                printf("%s\n",common);
                return 0;
            }
    }
    return 0;
}

4分数比较
题目内容:
比较两个分数的大小。人工方式下比较分数大小最常见的方法是:进行分数的通分后比较分子的大小。可以编程模拟手工解决。
具体要求为首先输出(“Input two FENSHU:\n”),然后输入两个分数分子分母的值,格式为("%d/%d,%d/%d"),判断完成后输出("%d/%d<%d/%d\n")或("%d/%d>%d/%d\n")或("%d/%d=%d/%d\n");
程序运行结果示例1:
Input two FENSHU:
17/19,23/27↙
17/19>23/27
程序运行结果示例2:
Input two FENSHU
2/3,2/3↙
2/3=2/3
程序运行结果示例3:
Input two FENSHU:
1/7,1/2↙
1/7<1/2
输入提示信息:“Input two FENSHU:\n”
输入格式: “%d/%d,%d/%d”
输出格式:
如果前者大于后者输出提示信息:"%d/%d>%d/%d\n"
如果前者等于后者输出提示信息:"%d/%d=%d/%d\n"
如果前者小于后者输出提示信息:"%d/%d<%d/%d\n"

#include 

int main(){
    int numerator1,numerator2,denominator1,denominator2;
    printf("Input two FENSHU:\n");
    scanf("%d/%d,%d/%d",&numerator1,&numerator2,&denominator1,&denominator2);
    if(numerator1*denominator2>numerator2*denominator1)
        printf("%d/%d>%d/%d\n",numerator1,numerator2,denominator1,denominator2);
    else if(numerator1*denominator2==numerator2*denominator1)
        printf("%d/%d=%d/%d\n",numerator1,numerator2,denominator1,denominator2);
    else
        printf("%d/%d<%d/%d\n",numerator1,numerator2,denominator1,denominator2);
    return 0;
}

5百万富翁的换钱计
题目内容:
有一天,一位百万富翁遇到一个陌生人,陌生人找他谈一个换钱的计划,陌生人对百万富翁说:“我每天给你10万元,而你第一天只需给我1分钱,第二天我仍给你10万元,你给我2分钱,第三天我仍给你10万元,你给我4分钱……。你每天给我的钱是前一天的两倍,直到满一个月(30天)为止”,百万富翁很高兴,欣然接受了这个契约。请编程计算在这一个月中陌生人总计给百万富翁多少钱,百万富翁总计给陌生人多少钱。程序中浮点数的数据类型均为double。
输入格式: 无
输出格式:
输出百万富翁给陌生人的钱: “to Stranger: %.2f yuan\n”
输出陌生人给百万富翁的钱: “to Richman: %.2f yuan\n”

#include 
#define MONTH 30

int main(){
    int i;
    double richer=0.0,stranger=0.0,money=1.0;
    for(i=0;i<MONTH;i++){
        stranger+=100000;
        richer+=money;
        money*=2;
    }
    printf("to Stranger: %.2f yuan\n",richer/100);
    printf("to Richman: %.2f yuan\n",stranger);
    return 0;
}

6用计数控制的循环实现正数累加求和
题目内容:
输入一些整数,编程计算并输出其中所有正数的和,输入负数时不累加,继续输入下一个数。输入零时,表示输入数据结束。要求最后统计出累加的项数。
程序运行结果示例:
Input a number:
1↙
Input a number:
3↙
Input a number:
4↙
Input a number:
2↙
Input a number:
-8↙
Input a number:
-9↙
Input a number:
0↙
sum=10,count=4
输入提示信息: “Input a number:\n”
输入格式: “%d”
输出格式: “sum=%d,count=%d\n”

#include 
#define MONTH 30

int main(){
    int count=0,sum=0,num;
    printf( "Input a number:\n");
    scanf("%d",&num);
    while(num!=0){
        if(num>0){
            count++;
            sum+=num;
        }
        printf( "Input a number:\n");
        scanf("%d",&num);
    }
    printf("sum=%d,count=%d\n",sum,count);
    return 0;
}

7平方根表
题目内容:
输出100(n2<=100)以内整数的平方根表,n的值要求从键盘输入,并且满足n2<=100 (即n的平方值在100以内)。
程序运行结果示例:
2020年MOOCC语言程序设计精髓第十二周编程题练兵_第2张图片
输入提示:“Input n(n<=10):\n”
输入格式: “%d”
输出格式:
输出表头: “%7d”
输出每行的开头数字: “%d”
输出第m行n列中的值:"%7.3f"

#include 
#include 

int main(){
    int i,j,n;
    printf("Input n(n<=10):\n");
    scanf("%d",&n);
    for(i=0;i<n;i++)
        printf("%7d",i);
    printf("\n");
    for(i=0;i<n;i++){
        printf("%d",i);
        for(j=0;j<n;j++){
            printf("%7.3f",sqrt(i*10+j));
        }
        printf("\n");
    }
    return 0;
}

8最大公约数
题目内容:
按照如下函数原型编写子函数计算正整数a和b的所有公约数。第一次调用,返回最大公约数。以后只要再使用相同参数调用,每次返回下一个小一些的公约数。无公约数时,函数CommonFactors()返回-1,主函数中不输出任何信息。
函数原型: int CommonFactors(int a, int b)
程序运行结果示例1:
Input a and b:
100,50↙
Common factor 1 is 50
Common factor 2 is 25
Common factor 3 is 10
Common factor 4 is 5
Common factor 5 is 2
Common factor 6 is 1
程序运行结果示例2:
Input a and b:
7,-3↙
输入提示信息:“Input a and b:\n”
输入格式: “%d,%d”
输出格式: “Common factor %d is %d\n”

#include 

int number=1;

int CommonFactors(int a,int b){
    int i,temp,count=0;
    if(a<b){
        temp=a;
        a=b;
        b=temp;
    }
    for(i=b;i>=1;i--){
        if(a%i==0&&b%i==0){
            count++;
        }
        if(count==number)
            return i;
    }
    return -1;
}

int main(){
    int a,b;
    printf("Input a and b:\n");
    scanf("%d,%d",&a,&b);
    if(a>0&&b>0){
        while(CommonFactors(a,b)!=-1){
            printf("Common factor %d is %d\n",number,CommonFactors(a,b));
            number++;
        }
    }
    return 0;
}

9 23根火柴游戏
题目内容:
请编写一个简单的23 根火柴游戏程序,实现人跟计算机玩这个游戏的程序。为了方便程序自动评测,假设计算机移动的火柴数不是随机的,而是将剩余的火柴根数对3求余后再加1来作为计算机每次取走的火柴数。如果剩余的火柴数小于3,则将剩余的火柴数减1作为计算机移走的火柴数。但是计算机不可以不取,剩下的火柴数为1时,必须取走1根火柴。假设游戏规则如下:
1)游戏者开始拥有23根火柴棒;
2)每个游戏者轮流移走1 根、2 根或3 根火柴;
3)谁取走最后一根火柴为失败者。
2020年MOOCC语言程序设计精髓第十二周编程题练兵_第3张图片
游戏开始提示信息:“Game start!\n”
“Note: the maximum number is 3\n”
提示游戏者输入移动的火柴数:“Please enter the number of matches you are moving:\n”
游戏者输入错误数据的提示信息:“The number you entered is wrong,please re-enter!\n”
输入格式: “%d”
输出格式:
输出被游戏者移动的火柴数:“The number of matches you are moving is:%d\n”
输出被计算机移动的火柴数:“The number of matches that have been moved by the computer is:%d\n”
输出被游戏者或计算机移动后剩余的火柴数:“The number of matches left is:%d\n”
游戏者获胜的输出提示信息:“Congratulations!You won!\n”
游戏者失败的输出提示信息:“I’m sorry. You lost!\n”

#include 

int main(){
    int match=23,player,computer;
    printf("Game start!\n");
    printf( "Note: the maximum number is 3\n");
    while(match!=0){
        printf("Please enter the number of matches you are moving:\n");
        scanf("%d",&player);
        if(player<=0||player>3||player>match){
            printf("The number you entered is wrong,please re-enter!\n");
            continue;
        }
        printf("The number of matches you are moving is:%d\n",player);
        match-=player;
        printf("The number of matches left is:%d\n",match);
        if(match==0){
            printf("I'm sorry. You lost!\n");
            break;
        }
        if(match>=3)
            computer=match%3+1;
        else
            computer=1;
        match-=computer;
        printf("The number of matches that have been moved by the computer is:%d\n",computer);
        printf("The number of matches left is:%d\n",match);
        if(match==0){
            printf("Congratulations!You won!\n");
            break;
        }
    }
    return 0;
}

你可能感兴趣的:(#,CSP)