《C语言及程序设计》实践参考——歌手大奖赛计分函数版

返回:贺老师课程教学链接  项目要求

【项目2-歌手大奖赛计分函数版】
(1)在歌手大奖赛中,有n位评委为参赛的选手打分,分数为0~10分(运行时由人输入)。选手最后得分为:去掉一个最高分和一个最低分后其余分数的平均值。请编写一个程序,完成相关的功能。

要求利用一个函数void calScore(int n),对一位选手成绩的输入成绩、计算和显示实现,其中n为评委人数。这样,在main函数调用时,需要将输入的评委人数n作为实参。
[参考解答]

#include<stdio.h>
void calScore(int n);
int main( )
{
    int n;   //评委人数
    printf("输入评委人数: ");
    scanf("%d", &n);
    calScore(n);
    return 0;
}

void calScore(int n)//参数n为评委人数
{
    int i;
    double ave, score, sum, max, min;  //这几个变量涉及成绩,double是合理的
    i=1;    //i代表评委的编号,其实这个变量名起得不好
    max=-1;  //这儿有技巧,第1位评委给的成绩一定大于-1,max将变成第1个成绩
    min=11;  //同样和技巧,要学会这样“设圈套”
    sum=0;
    printf("请输入选手的成绩(0-10)\n");
    do  //至少有一位评委,用do循环
    {
        printf("第 %d 位评委给分:", i);
        scanf("%lf", &score);
        sum+=score;
        if(max<score)
            max=score;
        if(min>score)
            min=score;
        i++;
    }
    while(i<=n);
    //下面开始计算
    ave = (sum-max-min)/(n-2);
    printf("减去一个最高分: %.2f", max);
    printf(", 减去一个最低分: %.2f \n", min);
    printf("当前选手的最后得分是:%.3f \n", ave);
}

(2)进一步完善(1)的程序。输入时,难免有录入错误发生,如果输入的成绩不在0-10之间,要求用户立即重新输入(在函数calScore中修改);一次运行程序只计算一位选手成绩太麻烦,要求输出当前选手的最后得分后,提示“按任意键计算下一位选手的成绩,退出请选择N:”如果输入的不是N或n,可以为下一位选手计算成绩(在main函数中进行控制即可)。

[参考解答]

#include<stdio.h>
void calScore(int n);
int main( )
{
    int n;   //评委人数
    char choice;
    printf("输入评委人数: ");
    scanf("%d", &n);
    do
    {
        calScore(n);
        printf("******************* SUCCESS ***********************\n");
        printf("按 N 退出,其他键继续....");
        fflush(stdin);   //读入字符前,常要清空“输入缓存区”
        scanf("%c", &choice); //用choice=getchar();也行
        printf("\n");
    }
    while(choice!='N' && choice!='n');  //不管输入大小写,全算数
    return 0;
}

void calScore(int n)//参数n为评委人数
{
    int i;
    double ave, score, sum, max, min;  //这几个变量涉及成绩,double是合理的
    i=1;    //i代表评委的编号,其实这个变量名起得不好
    max=-1;  //这儿有技巧,第1位评委给的成绩一定大于-1,max将变成第1个成绩
    min=11;  //同样和技巧,要学会这样“设圈套”
    sum=0;
    printf("请输入选手的成绩(0-10)\n");
    do  //至少有一位评委,用do循环
    {
        printf("第 %d 位评委给分:", i);
        scanf("%lf", &score);
        if(score<0||score>10)
            continue;  //输入不对就继续输,continue
        sum+=score;
        if(max<score)
            max=score;
        if(min>score)
            min=score;
        i++;
    }
    while(i<=n);
    //下面开始计算
    ave = (sum-max-min)/(n-2);
    printf("减去一个最高分: %.2f", max);
    printf(", 减去一个最低分: %.2f \n", min);
    printf("当前选手的最后得分是:%.3f \n", ave);
}
时间: 2024-10-12 11:23:16

《C语言及程序设计》实践参考——歌手大奖赛计分函数版的相关文章

C++第11周项目5——歌手大奖赛计分

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目5-歌手大奖赛计分系列] 参考运行图: (1)在歌手大奖赛中,有10个评委为参赛的选手打分,分数为0~10分(运行时由人控制).选手最后得分为:去掉一个最高分和一个最低分后其余8个分数的平均值.请编写一个程序实现(可以先不考虑用自定义函数实现). 参考解答: #include <iostream> using namespace std; int main( )

C语言及程序设计提高例程-25 指针作函数参数

贺老师教学链接  C语言及程序设计提高 本课讲解 例:冒泡排序函数的新写法 #include <stdio.h> void bubblesort(int*, int); int main( ) { int i,a[10]= {3,5,9,1,3,6,-9,-7,10,12}; bubblesort(a,10); for(i=0; i<10; i++) printf("%d ", a[i]); return 0; } void bubblesort(int *p, in

《C语言及程序设计》实践参考——个人所得税计算器if语句版

返回:贺老师课程教学链接  项目要求 [项目:个人所得税计算器if语句版]编写选择结构程序,输入个人月收入总额,计算出他本月应缴税款和税后收入(计算办法见附:关于个人所得税的有关背景知识).(1)用if语句的嵌套完成:(2)可以在下面程序的基本框架基础上完成,如需其他变量自行增加 #include <stdio.h> int main ( ) { double dSalary,dTax=0,dNetIncome=0; printf("请输入您本月的收入总额(元):"); s

《C++语言基础》实践参考—— 链表类

返回:贺老师课程教学链接  项目要求 [项目 - 链表类]动态链表也是程序设计中的一种非常有用的数据结构.可以说,是否能够理解有关操作的原理,决定了你是否有资格称为"科班"出身.在后续的专业基础课中,相关的内容还会从不同的角度,反复地认识,反复地实践.不过,在现阶段多些体验,也是很有必要的了.(1)阅读下面的程序,回顾一下动态链表,阅读程序过程中,请用笔画一画形成链表的过程中指针值的变化. #include <iostream> using namespace std; s

C语言程序设计实践(OJ)-初识函数

2964: 查闰年 Description 大家知道如何判断某一年是否是闰年吗?这个问题可难坏了小编,小编在写一个查找m年到n年之间闰年的程序,却苦于判断闰年的函数不会写,据说 今天你有上机课,我就拿着这个问题来找你了– 闰年的条件是:能被4整除但不能被100整除,或能被400整除. #include <stdio.h> int leap_year(int n); /*声明判断闰年函数*/ int main() { int i; int cnt; /*计数,用于每行满8个换行*/ int m,

《C++语言基础》实践参考——旱冰场造价

返回:贺老师课程教学链接 [项目1 - 旱冰场造价] 有一个圆形的旱冰场地,场地内抹水泥,造价为每平方米M元,围栏用木条围成,每米造价N元,输入旱冰场半径,用程序计算出其造价. 一级提示: 先定义类,确定其数据成员和成员函数.在这里要定义的旱冰场类,实际我们只关心其面积和周长,根据面积计算场地内抹水泥的造价,根据周长计算围栏的造价.有了类的定义,在main函数中定义该类对象,调用成员函数即可以完成求解.二级提示: 实际上,对于旱冰场,我们只关心它就是一个圆.这就是设计中抓住了本质.于是,设计一个

《C++语言基础》实践参考——指向学生类的指针

返回:贺老师课程教学链接 [项目4-指向学生类的指针] 设计一个学生类Student,数据成员包括学号(num)和成绩(score),成员函数根据需要自行设计(建议配备需要的set.get函数,以及必要的输入或输出,给出的代码中也可以找到需要成员函数的线索).在main函数中,要做到: 建立一个对象数组,通过初始化,设置5个学生的数据,要求: 用指针指向数组首元素,输出第1.3.5个学生的信息: 设计一个函数int max(Student *arr);,用指向对象的指针作函数参数,在max函数中

《C++语言基础》实践参考——复数模板类

返回:贺老师课程教学链接 [项目6-复数模板类]    阅读教材例10.1.该例实现了一个复数类,但是美中不足的是,复数类的实部和虚部都固定只能是double型的.可以通过模板类的技术手段,设计Complex,使实部和虚部的类型为定义对象时指定的实际类型.    (1)要求类成员函数在类外定义.    (2)在此基础上,再实现减法.乘法和除法    你可以使用的main()函数如下. int main( ) { Complex<int> c1(3,4),c2(5,-10),c3; //实部和虚

《C++语言基础》实践参考——Josephus(约瑟夫环)问题

返回:贺老师课程教学链接  项目要求 [项目-Josephus(约瑟夫环)问题]n个小孩子围成一圈,从第一个小孩子开始顺时针方向数数字,到第m个小孩子离开,这样反反复复,最终只剩下一个小孩子,求第几个小孩子留下?    提示:约瑟夫环即是一个首尾相连的链表,在建立好这个环以后,从头结点开始,每次间隔m孩子删除一个结点,直至只余下一个结点(删除了n-1个).     参考下面的代码,也可以自行设计类. //链表结点kid,其中number为这个人的编号 struct kid { int numbe