第十五周上机任务-项目4

1./*   
02. * Copyright (c) 2012, 烟台大学计算机学院   
03. * All rights reserved.   
04. * 文件名称:带姓名的成绩单.cpp   
05. * 作    者:  袁静  
06. * 完成日期:2012 年 12 月 8 日   
07. * 版 本 号:v1.0   
08. *   
09. * 输入描述:无   
10. * 问题描述:字符串数组的应用  
11. * 程序输出:略   
12. * 问题分析:略  
13. * 算法设计:略   
14. */    
#include<iostream>   
#include<cmath>   
#include<string>   
using namespace std;  
void input(double s[][4],int n);    
double max(double s[][4],int n,int i);    
double min(double s[][4],int n,int i);  
double avg(double s[][4],int n,int i);  
double stdev(double s[][4],int n,int i);  
output_result(double s[][4],int n);  
  
int main()  
{  
    int i,num;  
    string temp;  
    double score[100][4];   
    string course[4]={"高等数学","英语","C++","总分"};  
    cout<<"输入学生人数:";  
    cin>>num;  
       
    cout<<"输入学生成绩(按高数、英语、C++的顺序依次输入:)"<<endl;  
    for(i=0;i<num;++i)  
    {  
        cin>>score[i][0]>>score[i][1]>>score[i][2];  
        score[i][3]=score[i][0]+score[i][1]+score[i][2];  
   }  
    cout<<"输入的学生成绩为:"<<endl;  
    cout<<"学号\t高数\t英语\tC++\t总分"<<endl;  
    for(i=0;i<num;++i)  
    {  
        cout<<i<<'\t'<<score[i][0]<<'\t';  
       cout<<score[i][1]<<'\t';  
       cout<<score[i][2]<<'\t';  
       cout<<score[i][3]<<endl;  
    }  
      
       
   for(i=0;i<4;++i)  
   {  
        cout<<course[i]<<"的最高成绩是"<<max(score,num,i)<<", ";  
        cout<<"平均成绩是"<<avg(score,num,i)<<", ";  
        cout<<"成绩的标准偏差是"<<stdev(score,num,i)<<endl;  
    }  
       
   output_result(score,num);  
    return 0;  
}  
  
   
double max(double s[][4],int n,int j)  
{  
    double m=s[0][j];  
    for(int i=1;i<n;++i)  
       if (m<s[i][j])   
            m=s[i][j];  
       return m;  
}  
double min(double s[][4],int n,int j)  
{  
     double m=s[0][j]; 
	for(int i=1;i<n;++i)  
        if (m>s[i][j])   
     return m;  
}  
double avg(double s[][4],int n,int j)  
{  
    double sum=s[0][j];  
    for(int i=1;i<n;++i)  
       sum+=s[i][j];  
   return sum/n;  
}  
double stdev(double s[][4],int n,int j)  
{  
    double a,x,sum=0;  
    a=avg(s,n,j);   
    for(int i=0;i<n;i++)

{    
        x=s[i][j]-a;    
        sum+=x*x;    
   }    
   return sqrt(sum/(n-1));    
}  
 
    
output_result(double s[][4],int n)  
{  
    double m=max(s,n,3);  
    int i,c=0;  
   bool first=true;  
    cout<<"总分最高分为"<<m;  
   for(i=0;i<n;++i)  
    {  
        if(s[i][3]==m)  
            ++c;  
    }  
    cout<<",有"<<c<<"人达到最高分,他们的学号是:";  
    for(i=0;i<n;++i)  
    {  
        if(s[i][3]==m)  
            if(first)  
            {  
                cout<<i;  
                first=false;  
            }  
            else  
            {  
                cout<<"、"<<i;  
            }  
    }  
    cout<<endl;  
     
    m=min(s,n,3);  
    c=0;  
    first=true;  
    cout<<"总分最低分为"<<m;  
    for(i=0;i<n;++i)  
    {  
        if(s[i][3]==m)   
            ++c;  
   }  
   cout<<",有"<<c<<"人达到最低分,他们的学号是:";  
    for(i=0;i<n;++i)  
   {  
        if(s[i][3]==m)  
            if(first)  
            {  
                cout<<i;  
                first=false;  
            }  
            else  
            {  
                cout<<"、"<<i;  
           }  
    }  
   cout<<endl;  
}  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值