第17周报告(二)
实验目的:理解动态链表
实验内容:从文件中读入数据,利用动态链表,作出成绩单。
* 程序头部注释开始
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: 动态链表应用(高于平均分的为挂科同学信息)
* 作 者: 刘镇
* 完成日期: 2011 年 12 月 15 日
* 版本号: 1.020
* 对任务及求解方法的描述部分
* 输入描述:文件score.txt
* 问题描述:从文件score.txt中读入同学成绩(c++,高数,英语),求总成绩及平均分,将高于平均分并为挂科的同学的学号,姓名,总分输出。
* 程序输出:高于平均分并为挂科的同学的学号,姓名,总分
* 程序头部的注释结束、
#include<fstream>
#include<iomanip>
#include<string>
#include<iostream>
using namespace std;
struct student
{
char num[12];
string name;
float grade[3];
float score;
struct student *next;
};
student stu[180];
int main()
{
int i,sum = 0;
double ave = 0;
student*head=NULL, *p, *q;
ifstream infile( "score.txt", ios::in );
if(!infile)
{
cerr << "open error" << endl;
exit(1);
}
for(i = 0; i < 180; i++)
{
p = new student;
infile >> p->num >> p->name>> p->grade[0]
>> p->grade[1] >> p->grade[2] ;
p->next = NULL;
p->score = p->grade[0] + p->grade[1] + p->grade[2];
sum = p->score + sum;
if(i == 0)
head = p;
else
q->next = p;
q = p;
}
infile.close();
p = head;
ave = sum / 180 ;
cout <<"班级平均成绩:" << ave << endl;
cout << "高于平均分并且未挂科的同学有:" << endl;
cout << "学生号码" <<'\t'<<"学生姓名" <<'\t'<<"总成绩"<< endl ;
while(p!=NULL)
{
for(i = 0; i < 180; i++)
{
if(p->score > ave && p->grade[0] > 60 && p->grade[1] > 60 && p->grade[2] >60)
{
cout << p->num <<'\t'<< p->name<<'\t'<<'\t'<<p->score <<endl;
}
p = p->next;
}
}
return 0;
}
运行结果:
C++程序设计实验报告(二十三)
经验积累:
1.动态分配更为简单,十分易懂,->更加明了。
2.有了上一个的经验,这个更简单了,但还是被输出数据不能完全对其而困扰。
上机感言:这份作业是对于new的初次体验,但未用撤销内存,以后可以多加联系。课本还是要好好认真看看,不仅对于考试有好处,在一些理解上的偏差也可以补漏。