提高篇编程项目 第十九讲项目二/三 成绩处理 当年第几天(数组方案)
来源:互联网 发布:财务战略矩阵象限 编辑:程序博客网 时间:2024/06/08 04:26
任务和代码:
【项目2- 成绩处理】
在数组score中将要存储某小组C程序设计的成绩,请完成下面的处理:
(1)输入小组人数及成绩,要保证成绩在0-100之间;
(2)输出该小组的最高成绩、最低成绩、平均成绩;
(3)输出考得最高成绩和最低成绩的同学的人数;
(4)输出考得最高成绩和最低成绩的同学的学号(设数组下标即学号,可能有相同的成绩)。
(5)(选做)求出所有同学成绩的标准偏差,标准偏差公式为,其中为样本(即某同学成绩),为均值(前面已经求出),N为样本数目;
提示1:可以采用“渐进式”策略,实现一个功能后调试通过,再实现下一个功能。
提示2:界面参考见图
提示3:请思考,如果这里的同学人数很多,例如500、10000名,这个程序中通过键盘输入的方式,已经显得无能为力!如何解决?
int main() { int score[50]; //保存成绩的数组,不会超过50名 int num,i; //小组人数 printf("小组共有多少名同学?"; scanf("%d", &num); printf("请输入学生成绩:\n") //输入num名同学的成绩 //求出并输出最高成绩、最低成绩和平均成绩 //求出并输出考得最高成绩和最低成绩人数以及学号 //求出并输出标准偏差(选做) return 0; }
补全后的代码:
/**Copyright (c) 2016, CSDN学院*All rights reserved.*文件名:main.c*作者:DylanLiu*完成日期:2016/11/05*版本号:V1.0**问题描述:。*程序输出:。*/#include<stdio.h>#include<math.h>#define N 100int main(void){ int score[50]; //保存成绩的数组,不会超过50名 int num,i; //小组人数 int max=0, min=100;//先假定最高成绩和最低成绩 int sum=0; //分数总和 float ave=0.0;//平均成绩 int max_num=0, min_num=0;//最高分和最低分的人数 float sum_s=0.0;//方差的和 float s=0.0;//标准偏差 printf("小组共有多少名同学? "); scanf("%d", &num); printf("请输入学生的成绩:\n"); //输入num名同学的成绩 for(i=0; i<num; i++) do{ printf("输入第 %d 位同学的成绩:", i+1); scanf("%d", &score[i]); }while(score[i]<0||score[i]>100);//do循环中必须要执行一次,而这一次刚好可以用来输入数据 //当数据不符合要求时while(......)成立,则重新输入。若数据没有错误, 则有for(......)来 //控制所有的数据输入 //求出并输出最高成绩、最低成绩和平均成绩 for(i=0; i<num; i++){ if(score[i]>max) max=score[i]; if(score[i]<min) min=score[i]; sum += score[i]; } ave=sum/num; printf("最高成绩为: %d, 最低成绩为: %d, 平均成绩为: %.2f\n", max, min, ave); //求出并输出考得最高成绩和最低成绩人数以及学号 for (i=0; i<num; i++){ if (score[i]==max) max_num++; if (score[i]==min) min_num++; } printf("取得最高成绩%d, 共%d人; 他们的学号分别是:", max, max_num); for(i=0; i<num; i++){ if(score[i]==max) printf("%d", i); } printf("\n"); printf("取得最低成绩%d, 共%d人; 他们的学号分别是:", min, min_num); for(i=0; i<num; i++){ if(min==score[i]) printf("%d", i); } printf("\n"); //求出并输出标准偏差(选做) for(i=0; i<num; i++){ sum_s += (score[i]-ave)*(score[i]-ave); } s=sqrt( (sum_s)/(num-1) ); printf("标准偏差为:%.2f\n", s); return 0;}
输出结果:
任务和代码:
【项目3-当年第几天(数组方案)】
当年第几天中定义一个函数,其参数为年、月、日的值,返回这一天为该年的第几天。要求在main函数中输入年月日,然后调用这个函数求值,并在main函数中输出结果。
/**Copyright (c) 2016, CSDN学院*All rights reserved.*文件名:main.c*作者:DylanLiu*完成日期:2016/11/05*版本号:V1.0**问题描述:。*程序输出:。*/#include<stdio.h>int days(int y, int m, int d);int isleapyear(int year);int main(){ int year, month, day; printf("输入年 月 日: "); scanf("%d %d %d", &year, &month, &day); printf("这是该年的第 %d 天\n", days(year, month, day)); return 0;}int days(int y, int m, int d){ int dd[13]={0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; int sum_days=0; int i=0; //请利用d数组,10行之内,求出并返回y年m月d日是这一年的第几天 (isleapyear(y)) ?(dd[2]=29):(dd[2]=28) ; for(i=0; i<m; i++){ sum_days += dd[i]; } sum_days += d; return sum_days;}int isleapyear(int year){ int leapyear=0; if((year%4==0 && year%100!=0) || year%400==0) leapyear=1; return leapyear;}
输出结果:
0 0
- 提高篇编程项目 第十九讲项目二/三 成绩处理 当年第几天(数组方案)
- 提高篇第十六讲项目3-当年第几天(数组方案)
- 提高项目14-当年第几天(数组方案)
- 提高篇第一讲项目5-当年第几天
- (提高篇)第十九讲 编程项目 数组的练习
- 提高项目5-当年第几天
- 提高篇项目5——当年第几天
- 提高篇编程项目 第十九讲 扑克牌 发奖金
- 提高篇十六讲——项目2- 成绩处理
- 第12周项目4-计算当年第几天(二)
- 提高第18课时,实践3,当年第几天(数组方案)
- 第43讲--项目三--成绩统计
- 第26讲-项目二-成绩等级
- 第十二周项目五 判断当年第几天(数组法)
- 第七周项目二自选图形用户界面程序开发(当年第几天)
- 第十一周项目五:当年第几天(改进版)
- 第十二周项目一 当年第几天
- 第十二周项目1-当年第几天
- 第十周—输出一万以内回文数
- 关于使用 JSON 的笔记
- Git(三):管理修改
- Java并发---- Executor并发框架--线程池,ThreadToolExecutor初步理解
- HDOJ杭电oj 1021Fabonacci Again 的一个愚蠢而又快速的方法
- 提高篇编程项目 第十九讲项目二/三 成绩处理 当年第几天(数组方案)
- Android架构
- 深入理解Java:注解(Annotation)基本概念
- 郝斌的C语言基础 042 运算符关系
- 古人的字、号、别称
- 文章标题
- poj_2488 A Knight's Journey(dfs)
- Jquery中可以移除hover的代码
- iOS网络请求优化之DNS映射