【第22期】观点:IT 行业加班,到底有没有价值?

第十四周项目三-成绩处理函数模版

原创 2013年12月02日 18:46:02
#include<iostream>
#include<cmath>
using namespace std;
void input_score(int s[], int n); //将小组中n名同学的成绩输入数组s
int get_max_score(int s[], int n);  //返回数组s中n名同学的最高成绩值
int get_min_score(int s[], int n);  //返回数组s中n名同学的最低成绩值
double get_avg_score(int s[], int n);  //返回数组s中n名同学的平均成绩值
double get_stdev_score(int s[], int n); //返回数组s中n名同学成绩值的标准偏差
int count(int x, int s[], int n);  //返回在数组s中n名同学中有多少人得x分(实参给出最高/低时,可以求最高/低成绩的人数)
void output_index(int x, int s[], int n); //在函数中输出数组s中n名同学中得x分的学号(下标)

int main(void)
{
  int score[50]; //将score设为局部变量,通过数组名作函数参数,传递数组首地址,在函数中操作数组
  int num;       //小组人数也设为局部变量,将作为函数的实际参数
  int max_score,min_score;
  cout<<"小组共有多少名同学?";
  cin>>num;
  cout<<endl<<"请输入学生成绩:"<<endl;
  input_score(score, num);  //要求成绩在0-100之间
  max_score=get_max_score(score, num);
  cout<<endl<<"最高成绩为:"<<max_score<<",共有 "<<count(max_score, score, num )<<" 人。";
  min_score=get_min_score(score, num);
  cout<<endl<<"最低成绩为:"<<min_score<<",共有 "<<count(min_score,score, num )<<" 人。";
  cout<<endl<<"平均成绩为:"<<get_avg_score(score, num);
  cout<<endl<<"标准偏差为:"<<get_stdev_score(score, num);
  cout<<endl<<"获最高成绩的学生(学号)有:";
  output_index(max_score,score, num);
  cout<<endl<<"获最低成绩的学生(学号)有:";
  output_index(min_score,score, num);
  cout<<endl;
  return 0;
}
void input_score(int s[], int n)//定义函数不加“;”
{
    int i;
    for(i=0;i<n;i++)
    do
    {
        cout<<"输入第"<<i<<"位同学的成绩";
        cin>>s[i];
    }while(s[i]<0||s[i]>100);
    return;
}
int get_max_score(int s[], int n)
{
    int i,max=s[0];
    for(i=0;i<n;i++)
    {
        if(s[i]>max) max=s[i];
    }

    return max;
}
int get_min_score(int s[], int n)
{
    int i,min=s[0];
    for(i=0;i<n;i++)
    {
      if(s[i]<min) min=s[i];
    }

    return min;
}
double get_avg_score(int s[], int n)
{
    double sum=0,avg;
    int i;
    for(i=0;i<n;i++)
    {
       sum+=s[i];
    avg=sum/n;
    }

    return avg;
}
double get_stdev_score(int s[], int n)
{
    int i,m=0,k;
    k=get_avg_score(s,n);
    for(i=0;i<n;i++)
    m+=(s[i]-k)*(s[i]-k);
    return sqrt(m/(n-1));
}
int count(int x, int s[], int n)
{
    int i,j=0;
    for(i=0;i<n;i++)
    {
        if(s[i]==x)
        j++;
    }

    return j;
}

void output_index(int x, int s[], int n)
{
    int i;
    for(i=0;i<n;i++)
    {
        if(s[i]==x)
        cout<<i<<" ";
    }
    return ;
}


运行结果:

心得体会:

版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

第十四周实验--任务1--建立专门的数组类处理有关数组的操作

/* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称:建立专门的数组类处理有关数组的操作 <

第十四周 实践项目<2> ---成绩处理函数版

 Copyright (c) 2016, 烟台大学计算机与控制学院 All ringts reserved.  文件名称:实践项目 ---成绩处理函数版 作 者:王兴振 完成日期:201...

程序员升职加薪指南!还缺一个“证”!

CSDN出品,立即查看!

第十四周实验--任务2--建立专门的链表类处理有关动态链表的操作

<p style="padding-right: 0px; padding-left: 0px; font-s

第十四周拓展项目2—成绩处理函数版

 /*  Copyright(c)2016,烟台大学计算机学院   All rights reserved.  文件名称:tset.cpp  作者:尤文敏  完成日...

《C++第十四周实验报告1-1》---建立专门的数组类处理有关数组的操作

/* 【任务1】建立专门的数组类处理有关数组的操作 数组是几乎所支持的组织数据的方法。C和C++对数组类型提供了内置支持, 使我们利用数组实现软件中需要的各种实用的功能。但是,这种支持仅限于用来读写单个元素的机制。 C++不支持数组的抽象abstraction,也不支持对整个数组的操作。例如:把一个...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)