02周:项目二:结构体应用:有序的结构体数组。
来源:互联网 发布:javascript代码规范 编辑:程序博客网 时间:2024/03/29 08:14
/** Copyright (c) 2014, 烟台大学计算机学院* All rights reserved.* 作 者:王颖* 完成日期:2014 年 3 月 6 日* 版 本 号:v1.0* 输入描述: 无* 问题描述:结构体应用:有序的结构体数组。/计算总分和均分* /按总分降序排序/按学号升序排序/输出成绩单/输出优秀者:总分超285,单科不低于90* 程序输出:略* 问题分析:略* 算法设计:略*/#include <iostream>#include <string>using namespace std;struct Student{ char num[13]; char name[10]; int cpp; int math; int english; int grade; double average;};void calculate(Student s[],int n); //计算总分和均分,数据在s数组中,共有n个元素void sort1(Student [],int); //按总分降序排序void sort2(Student [],int); //按学号升序排序void output(Student [],int); //输出成绩单void outputExcellent(Student [],int); //输出优秀者:总分超285,单科不低于90int main(){ Student stu[]= {{"201152501104","Tom",65 ,69 ,68 }, {"201152501114","Jeery",94 ,89 ,63 }, {"201152501138","Speike",67 ,62 ,84 }, {"201152501204","Tyke",100 ,95 ,91 }, {"201152501202","Tuffy",59 ,80 ,55 }, {"201152501115","Butch",100 ,99 ,89 }, {"201152501201","Lightin",95 ,92 ,99 }, {"201152501145","Topsy",88 ,56 ,67 }, {"201152501203","Droopy",62 ,62 ,95 }, {"201152501140","Drupa",80 ,60 ,86 }, {"201152501205","Buzz",73 ,90 ,94} }; int stuNum=sizeof(stu)/sizeof(stu[0]); //用sizeof运算确定数组中元素个数 //计算总分和均分后输出 calculate(stu,stuNum); cout<<"下面是成绩单:"<<endl; output(stu,stuNum); cout<<"优秀者名单:"<<endl; outputExcellent(stu,stuNum); //按总分降序排序后输出 sort1(stu,stuNum); cout<<"按总分降序排序后:"<<endl; output(stu,stuNum); //按学号升序排序后输出 sort2(stu,stuNum); cout<<"按学号升序排序后:"<<endl; output(stu,stuNum); return 0;}//计算总分和均分,数据在s数组中,共有n个元素void calculate(Student s[],int n){ int i; for(i=0; i<n; i++) { s[i].grade=s[i].cpp+s[i].math+s[i].english; s[i].average=s[i].grade/3; }}//按总分降序排序void sort1(Student s[],int n){ int i,j; Student t; for(i=0; i<n-1; i++) for(j=0; j<n-i-1; j++) { if(s[j].grade<s[j+1].grade) { t=s[j]; s[j]=s[j+1]; s[j+1]=t; } }}//按学号升序排序void sort2(Student s[],int n){ int i,j; Student t; for(i=0; i<n-1; i++) for(j=0; j<n-i-1; j++) { if(s[j].num>s[j+1].num) //t.num=s[j].num;这样不对,因为char[]不能直接赋值。不光要换学号,后边的成绩,名字也要换 { t=s[j]; s[j]=s[j+1]; s[j+1]=t; } }}//输出成绩单void output(Student s[],int n){ int i; cout<<"学号"<<'\t'<<'\t'<<"姓名"<<'\t'<<"总分"<<'\t'<<"均分"<<endl; for(i=0; i<n; i++) { cout<<s[i].num<<'\t'<<s[i].name<<'\t'<<s[i].grade<<'\t'<<s[i].average; cout<<endl; }}//输出优秀者:总分超285,单科不低于90void outputExcellent(Student s[],int n){ int i; cout<<"学号"<<'\t'<<'\t'<<"姓名"<<'\t'<<"总分"<<'\t'<<"均分"<<endl; for(i=0; i<n; i++) { if((s[i].grade>=285)&&(s[i].cpp>=90)&&(s[i].math>=90)&&(s[i].english>=90)) { cout<<s[i].num<<'\t'<<s[i].name<<'\t'<<s[i].grade<<'\t'<<s[i].average; cout<<endl; } }}
心得体会:有时候心理作用很大。
0 0
- 02周:项目二:结构体应用:有序的结构体数组。
- 项目二有序的结构体数组
- 【结构体数组】项目二。有序的结构体数组
- 二周 项目2 有序的结构体数组
- 第二周项目二-有序的结构体数组
- 第 二周项目2有序的结构体数组
- 第二周 项目二 有序的结构体数组
- 有序的结构体数组二
- 项目1.有序的结构体数组】
- 项目1-有序的结构体数组
- 项目2-有序的结构体数组
- 第二周(项目二)——有序的结构体数组。
- 第二周 项目二 有序的结构数组
- 第二周项目一:有序的结构体数组
- 第二周 项目一:有序的结构体数组
- 第2周项目一-有序的结构体数组
- 第二周项目1 有序的结构体数组
- 第二周项目2-有序的结构体数组
- Linux下zip包的压缩与解压缩[转]
- C#的封装、继承和多态
- Android 今日收获
- Netra(DM8168)基于Rdk平台的软件框架设计
- 项目5点结构体与枚举
- 02周:项目二:结构体应用:有序的结构体数组。
- android apk包反编译、破解心得
- Servlet编程之自定义标签
- Device Tree
- QT UI编程细节(待续)
- 如何用JavaScript实现类似于ListBox功能
- 软工文档总结
- SaeMysql l类
- 02周:项目三:文件加结构体实现系统