- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
c语言第七次上机作业呈报
青 岛 理 工 大 学
课程实验报告
课程名称 计算机程序设计 (C) 班级 软件112 实验日期 2012.5.6 姓名 王涛 学号 201107235 实验成绩 实验名称 实验七 链表
实
验
目
的
及
要
求
1.掌握结构体类型变量的定义和使用。
2.掌握结构体类型数组的概念和应用。
3.掌握链表的概念,初步学会对链表进行操作。
实
验
环
境
VC++6.0
实
验
内
容
1.编写程序。有5个学生,每个学生的数据包括学号、姓名、3门课的成绩,从键盘输入5个学生数据,要求输出3门课总平均成绩,以及最高分的学生的数据(包括学号、姓名、3门课的成绩、平均分数)。
2.建立一个学生链表,每个结点包括:学号、姓名、性别、年龄。输入一个年龄,如果链表中的结点所包含的年龄等于此年龄,则将此结点删去。
算
法
描
述
及
实
验
步
骤
1, 建立适当的结构体
2,定义相似类型的指针变量
3,创建链表
4,输出链表
5,调用函数实现分数的处理
调
试
过
程
及
实
验
结
果
头指针的定义,以及头结点,首节点,尾节点
结构体的两种定义形式(typedef)
结构体部分指针的定义形式
4、利用scanf函数时,地址的写法很容易出错
总
结
掌握好基础知识,有些地方还需要查找资料。
附
录
1、#includestdio.h
typedef struct
{ int num;
char name[10];
float score[3];
double aver;
}student;
void inputs(student stu[])
{ int i,k;
for(i=0;i2;i++)
{ printf( 第%d个学生:,i+1);
scanf(%d%s,stu[i].num,stu[i].name);/* 输入学生学号、姓名*/
printf(输入分数);
for(k=0;k3;k++)
scanf(%f,stu[i].score[k]); /*输入学生三门课的分数*/
}
}
void average( student stu[]) /*求学生的平均分*/
{ int i,k;
for(i=0;i2;i++)
{ float sum=0.0;
for(k=0;k3;k++)
sum+=stu[i].score[k];
stu[i].aver=sum/3;
}
}
void Printf( student stu[])/*输出学生信息*/
{ int i,k;
printf(输出执行结果:\n);
for(i=0;i2;i++)
{
printf(\t第%d个学生:\t学号:%d \t姓名:%s\t分数:,i+1,stu[i].num ,stu[i].name);
for(k=0;k3;k++)
printf(%g ,stu[i].score[k]);
printf(\t平均分:%g,stu[i].aver );
printf(\n);
}
}
void Max( student stu[])
{int i;
int max=0;
for(i=1;i2;i++)
if(stu[max].aver stu[i].aver )
max=i;
printf(%g\n,stu[max].aver );
}
void main()
{
student stu[2];
printf(输入数据:\n);
inputs(stu);
average(stu);
Printf(stu);
Max(stu);
}
#includestdio.h
#includemalloc.h
#define LEN sizeo(struct student)
struct student
{
char num[6];
char name[8];
char sex[2];
int age;
struct student *next;
}stu[10];
void main()
{
struct student *p,*pt,*head;
int i,length,iage,flag=1;
int find=0;
while(flag==1)
{
printf(input length of list(10):);
scanf(%d,length);
文档评论(0)