寒假学术休假项目7-大奖赛计分系统(实用版)

问题及代码:
/*   
*Copyright (c)2015,烟台大学计算机与控制工程学院   
*All rights reserved.   
*文件名称:score.cpp   
*作    者:单昕昕   
*完成日期:2015年2月22日   
*版 本 号:v1.0   
*   
*问题描述:大奖赛计分系统(实用版)
*程序输入:选手、裁判人数,选手分数等。
*程序输出:分数及排名等。  
*/ 
#include <iostream>
#include <iomanip>
#include <cstdio>
using namespace std;
double s[1000][20];
void input_mark(int m,int n,double s[][20],double p,double q);
void sort1(int m,int n,double s[][20]);
void sort2(int m,int n,double f[][2]);
void output_mark(int m,int n,double s[][20]);
void calculate_mark(int max,int min,double s[][20],int x,double f[][2]);
int main()
{
    int m,n,x;
    cout<<"请输入评委的人数:";
    cin>>m;
    cout<<"请输入选手的人数:";
    cin>>n;
    double max,min,f[n][2];
    cout<<"——————————————————————"<<endl;
    cout<<"请输入打分范围:"<<endl;
    cout<<"——————————————————————"<<endl;
    cout<<"最低分:";
    cin>>min;
    cout<<"最高分:";
    cin>>max;
    cout<<"请输入选手的成绩:"<<endl;
    input_mark(m,n,s,min,max);
    cout<<"选手成绩降序排列如下:"<<endl;
    sort1(m,n,s);
    output_mark(m,n,s);
    cout<<"请输入要去掉的最值数目:";
    cin>>x;
    calculate_mark(m,n,s,x,f);
    cout<<"选手的最终排名为:"<<endl;
    sort2(m,n,f);
    return 0;
}
void input_mark(int m,int n,double s[][20],double p,double q)
{
    int i,j;
    for(i=0; i<n; i++)
    {
        cout<<"选手"<<i<<":";
        for(j=0; j<m;)
        {
            cin>>s[i][j];
            if(s[i][j]>=p&&s[i][j]<=q)
            {
                ++j;
            }
            else
            {
                cout<<"分数不在正确的范围内,请检查并请重新输入该选手的成绩"<<endl;
                j--;
            }
        }
    }
}
void sort1(int m,int n,double s[][20])
{
    int i,j,k;
    double t;
    for(k=0; k<n; k++)
        for(j=0; j<=m-1; j++)
            for(i=0; i<m-j-1; i++)
                if (s[k][i]<s[k][i+1])
                {
                    t=s[k][i];
                    s[k][i]=s[k][i+1];
                    s[k][i+1]=t;
                }
}
void output_mark(int m,int n,double s[][20])
{
    int i,j;
    for(i=0; i<n; ++i)
    {
        cout<<"选手"<<i<<":";
        for(j=0; j<m; ++j)
            cout<<s[i][j]<<'\t';
        cout<<endl;
    }
}
void calculate_mark(int m,int n,double s[][20],int x,double f[][2])
{
    double sum;
    int i,j;
    for(i=0; i<n; ++i)
        f[i][0]=i;
    for(i=0; i<n; ++i)
    {
        sum=0;
        for(j=x; j<m; ++j)
        {
            sum+=s[i][j];
        }
        cout<<"选手"<<i<<"得分是:"<<(sum/(m-x))<<"分"<<endl;
        f[i][1]=sum/(m-x);
    }
}
void sort2(int m,int n,double f[][2])
{
    int i,j,k;
    double t;
    for(j=0; j<=m-1; j++)
        for(i=0; i<m-j-1; i++)
            if (f[i][1]<f[i+1][1])
            {
                t=f[i][1];
                f[i][1]=f[i+1][1];
                f[i+1][1]=t;
                k=f[i][0];
                f[i][0]=f[i+1][0];
                f[i+1][0]=k;
            }
    for(i=0; i<n; ++i)
            cout<<"第"<<i<<"名:"<<"选手"<<f[i][0]<<endl;
}



运行结果:


知识点总结:

吐血。。好多函数。。

注意对应。。


学习心得:

一定要耐下心啊啊啊~~~

二维数组作函数参数的时候一定要固定好第二维。。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值