《C语言程序设计》综合实习报告 2.docx
《《C语言程序设计》综合实习报告 2.docx》由会员分享,可在线阅读,更多相关《《C语言程序设计》综合实习报告 2.docx(16页珍藏版)》请在冰豆网上搜索。
《C语言程序设计》综合实习报告2
课题一:
用指针优化学生成绩排名
一、目的
1.熟悉变量的指针和指向变量的的指针变量的概念和使用
2.熟悉数组的指针和指向数组的的指针变量的概念和使用
3.掌握冒泡法或选择法排序的算法
4.掌握函数的定义、调用、声明,以及参数的两种传递方式
二、实习环境
个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC++等编译开发环境
三、实习内容与步骤
1.定义一个数组stu[10]存放10个学生的成绩,从键盘输入数据,要求用指针实现
2.将数组stu[10]的内容输出到屏幕上,要求用指针实现
3.将成绩数组按照从高到低进行排序,要求用指针实现
4.将第三步内容放在函数中实现,在主函数中调用实现排序,用指针实现,输出排序后的成绩单
5.采用指针方法,输入字符串“studentscore”,复制该字符串并输出(复制字符串采用库函数或用户自定义函数)
6.在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段运行结果(屏幕截图)。
7.在实习报告中说明知识点。
8.在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。
四、程序流程图、算法及运行结果
1.程序流程图:
2.算法:
先定义一个函数接收10个学生的成绩,利用指针将数据保存在数组中,再定义第二个函数输出所以学生的成绩,同样也是使用指针,最后定义一个函数用选择排序法对成绩进行由大到小的排序,将指针指向的是数组中的第一个地址,在主函数中依次调用这两个函数;
定义一个字符指针指向字符串,利用库函数中的strcpy将studentscore复制给字符指针,输出字符串
3.程序:
#include"stdio.h"
#include"string.h"
structstudent
{
intgrade;
intnum;
}stu[10];
voidinput(structstudent*p)
{inti;
for(i=0;i<10;i++,p++)
{printf("请输入第%-2d个学生的成绩:
",i+1);
scanf("%d%d",&p->num,&p->grade);}
}
voidprintout(structstudent*p)
{inti;
for(i=0;i<10;i++,p++)
printf("第%-2d个学生的成绩为:
%d\n",i+1,p->grade);
}
voidarrow(int*p1,int*p2,int*px,int*py)
{intt,m;
t=*px;*px=*py;*py=t;
m=*p1;*p1=*p2;*p2=m;
}
voidplace(structstudentstu[])
{inti,j;
for(i=1;i<10;i++)
for(j=0;j<10-i;j++)
if(stu[j].gradearrow(&stu[j].num,&stu[j+1].num,&stu[j].grade,&stu[j+1].grade);
}
intmain(void)
{structstudentstu[10],*ptr;
inti;
charstring[100],*s;
s=string;ptr=stu;
input(ptr);
printout(ptr);
place(stu);
printf("排序后的成绩单为:
\n");
for(i=0;i<10;i++)
printf("第%-2d名%-2d%-5d\n",i+1,stu[i].num,stu[i].grade);
printf("\n");
strcpy(s,"studentscore");
printf("%s\n",string);
}
4.运行结果:
五、知识点、难点及解决办法。
主要考察的是利用指针作为函数参数以及指针数组的知识点,如何使指针指向数组并能将值返回给主函数是一个难点
首先定义一个整型指针指向数组stu[]的首地址,在自定义函数中运用循环结构实现指针的移动并分别存储各个学生的成绩返回给主函数
六、编程小结或体会。
编程时除了注意指针与函数如何调用外,还要注意细节问题,比如自定义变量类型的统一,循环结构的循环次数等等,要谨慎对待
课题二:
学生成绩单制作
一、目的
1.掌握结构体变量及数组的定义、赋值、初始化、输入、输出
2.结构体数组的操作。
二、实习环境
个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC++等编译开发环境
三、实习内容与步骤
1.定义一个结构体数组,存放10个学生的学号,姓名,三门课的成绩
2.从键盘输入10个学生的以上内容
3.输出单门课成绩最高的学生的学号、姓名、以及该门课程的成绩
4.输出三门课程的平均分数最高的学生的学号、姓名及其平均分
5.将10个学生按照平均分数从高到低进行排序,输出结果,格式如下所示:
numbernamemathChineseEnglishaverage
103tom909010095
101alice90807080
6.在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。
7.在实习报告中说明知识点。
8.在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会
四、程序流程图、算法及运行结果
1.程序流程图:
2.算法:
先定义一个结构体,存储学生的各项信息,定义一个结构体指针指向结构体数组,第一个函数比较每个学生单门课的成绩,返回每一门课最高分学生的stu的下标;第二个函数比较每个学生的平均分,返回平均分最高的学生;第三个函数主要按照平均分高低对学生进行排序,通过循环和选择排序法实现指针的移动以及重新排列,主函数中依次调用这三个函数
3.程序:
#include"stdio.h"
#defineN10
structstudent
{
longnumber;
charname[20];
floatgrade[3];
floataverage;
}stu[10];
inthanshu_best(structstudent*p,intm)
{intq,num;
floata;
a=p->grade[m];
num=0;
for(q=0;qif((p+q)->grade[m]>a)
{a=(p+q)->grade[m];
num=q;}
returnnum;
}
inthanshu_average(structstudent*p)
{inti,m,index;
floata;
for(m=0;m{p->average=0;
for(i=0;i<3;i++)
p->average=p->average+p->grade[i];
p->average=p->average*1.0/3;}
a=p->average;
for(m=0;mif(p->average>a)
{a=p->average;
index=m;}
else
index=0;
returnindex;
}
voidhanshu_place(structstudentstu[])
{inti,j;
structstudentt;
for(i=0;ifor(j=i;jif(stu[j+1].average>stu[i].average)
{t=stu[j+1];stu[j+1]=stu[i];stu[i]=t;}
}
voidmain()
{
structstudentstu[10],*ptr;
inti,j,index,m,num;
floataverage;
ptr=stu;
for(i=0;i{printf("请输入第%d个学生的学号、姓名及三科成绩:
\n",i+1);
scanf("%ld%s",&stu[i].number,stu[i].name);
for(j=0;j<3;j++)
scanf("%f",&stu[i].grade[j]);}
printf("\n");
for(m=0;m<3;m++)
{num=hanshu_best(ptr,m);
printf("学号%ld姓名:
%-10s最高分%-8.2f\n",stu[num].number,stu[num].name,stu[num].grade[m]);}
index=hanshu_average(ptr);
printf("\n三门课平均分最高的学生信息是:
\n");
printf("学号%ld姓名:
%-10s平均分%-8.2f\n",stu[index].number,stu[index].name,stu[index].average);
printf("\n10个学生由高分到低分排名为:
\n");
printf("numbernameMathChineseEnglishaverage\n");
hanshu_place(ptr);
for(i=0;i{printf("%-10ld%-10s%",stu[i].number,stu[i].name);
for(j=0;j<3;j++)
printf("%-10.2f",stu[i].grade[j]);
printf("%-10.2f\n",stu[i].average);}
}
4.运行结果:
五、知识点、难点及解决办法。
主要考察的是结构体指针的运用,比较难的地方也就是如何将指针指向结构体并返回我们所要的数值
先定义一个结构体数组,再定义一个结构体指针,令指针指向数组的首地址,在自定义函数中通过指针的运算实现数组的运算,并返回相应的值
六、编程小结或体会。
在输出我们所需要的数据时候可以通过一些小技巧使程序看起来更好看。
掌握结构体指针的技巧可以解决很多问题,使自己的程序具有解决多个复杂问题的能力,以后多练习此类的程序设计问题,使自己更加熟练
课题三:
学生成绩文件管理
一、目的
1.掌握文件指针的概念和运用
2.掌握文件的相关操作:
打开、读、写、关闭
3.掌握文件的定位操作
二、实习环境
个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC++等编译开发环境
三、实习内容与步骤
1.定义一个结构体数组,存放10个学生的学号,姓名,三门课的成绩
2.从键盘输入10个学生的以上内容,存入文件stud.txt,关闭文件
3.打开stud.txt文件,将数据读出,查看是否正确写入,关闭文件。
4.打开文件stud.txt文件,读出数据,将10个学生按照平均分数从高到低进行排序,
分别将结果输出到屏幕上和另一文件studsort.txt中。
5.在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。
6.在实习报告中说明知识点。
7.在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。
四、程序流程图、算法及运行结果
1.程序流程图:
2.算法:
首先创建一个可读可写的新文件stud.txt,键入十个学生的信息并储存在文件中,关闭程序;打开文件stud.txt,读出文件中的信息并输出,检查有无错漏,并按照平均分通过选择排序法对学生由高到低排序,关闭程序;将排好序的信息输出并存储在新的可写文件studsort.txt中
3.程序:
#include"stdio.h"
#include"stdlib.h"
#defineN10
structstudent
{
longnum;
charname[20];
intgrade[3];
}stu[10];
intmain(void)
{FILE*fp,*fpp;
structstudentstu[10],t;
floataverage[100];
inti=0,j;
if((fp=fopen("stud.txt","w+"))==NULL)
{printf("该文件打开失败!
");
exit(0);}
for(i=0;i{printf("第%-2d个学生的学号、姓名及三门课成绩:
\n",i+1);
scanf("%ld%s",&stu[i].num,stu[i].name);
fprintf(fp,"第%-2d个学生的学号、姓名及三门课成绩:
\n",i+1);
fprintf(fp,"%ld%-5s",stu[i].num,stu[i].name);
for(j=0;j<3;j++)
{scanf("%d",&stu[i].grade[j]);
fprintf(fp,"%d",stu[i].grade[j]);}
fprintf(fp,"\n");
}
if(fclose(fp))
{printf("该文件无法正常关闭!
\n");
exit(0);}
if((fp=fopen("stud.txt","r+"))==NULL)
{printf("该文件打开失败!
");
exit(0);}
printf("\n");
for(i=0;i{printf("第%d个学生的学号、姓名及三门课成绩:
\n",i+1);
fscanf(fp,"%ld%s",&stu[i].num,stu[i].name);
printf("%ld%-5s",stu[i].num,stu[i].name);
for(j=0;j<3;j++)
{fscanf(fp,"%d",&stu[i].grade[j]);
printf("%d",stu[i].grade[j]);}
printf("\n");
}
if(fclose(fp))
{printf("该文件无法正常关闭!
\n");
exit(0);}
if((fp=fopen("stud.txt","r+"))==NULL)
{printf("该文件打开失败!
");
exit(0);}
for(i=0;i{fscanf(fp,"%ld%s",&stu[i].num,stu[i].name);
for(j=0;j<3;j++)
fscanf(fp,"%d",&stu[i].grade[j]);}
for(i=0;i{for(j=0;j<3;j++)
average[i]=average[i]+stu[i].grade[j];
average[i]=average[i]*1.00/3;}
for(i=0;ifor(j=i;jif(average[j+1]>average[i])
{t=stu[j+1];stu[j+1]=stu[i];stu[i]=t;}
if(fclose(fp))
{printf("该文件无法正常关闭!
\n");
exit(0);}
if((fpp=fopen("studsort.txt","w+"))==NULL)
{printf("该文件打开失败!
");
exit(0);}
printf("\n由高到低排序为:
\n");
for(i=0;i{printf("%ld%-5s",stu[i].num,stu[i].name);
fprintf(fpp,"%ld%-5s",stu[i].num,stu[i].name);
for(j=0;j<3;j++)
{fprintf(fpp,"%d",stu[i].grade[j]);
printf("%d",stu[i].grade[j]);}
printf("\n");
fprintf(fpp,"\n");
}
if(fclose(fp))
{printf("该文件无法正常关闭!
\n");
exit(0);}
}
4.运行结果:
五、知识点、难点及解决办法。
主要考察对于文件信息的存储以及读取文件内的信息,难点在于如何将信息存储起来以及如何从文件中读取有效信息并显示在调式框中
首先定义一个指针指向文件,然后创建或是打开一个的文件,注意文件的类型和打开方式,如果是写入信息则用fprintf,如果是读取信息则是fscanf,注意写入和读取的书写格式,前面许注明指向该文件的指针
六、编程小结或体会。
通过文件的学习,以后调试程序后还可以将信息永久的保存起来随时使用或更改,不需要使用一次就输入一次,方便又省时间,
课题四:
链表的创建与使用
一、目的
1.掌握单向链表的概念
2.掌握单向链表的创建、查找、删除方法
二、实习环境
个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC++等编译开发环境
三、实习内容与步骤
1.创建一个单向链表,存放10个学生的学号,姓名,并输出这种10个学生的信息。
2.在链表中查找指定学号的学生,输出其姓名。
3.在链表中删除指定学号的学生,然后输出其余学生的信息。
4.在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。
5.在实习报告中说明知识点。
6.在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。
四、程序流程图、算法及运行结果
1.程序流程图:
2.算法:
用指针处理单向链表,定义一个头指针,尾指针,通过尾指针的移动实现数据信息的存储与读取;删除结点时,应该先将要删除结点前后的结点连上,然后再将其删除,保证链表不会“断”。
3.程序:
#include"stdio.h"
#include"stdlib.h"
#defineN10
#definelensizeof(structstudent)
structstudent
{
longnum;
charname[20];
structstudent*next;
};
voidsearch(structstudent*head)
{longnumber;
structstudent*p;
p=head;
printf("请输入要查找的学生学号:
");
scanf("%ld",&number);
do
{if(p->num==number)
printf("%-15s\n",p->name);
p=p->next;}while(p!
=NULL);
}
voidcdelete(structstudent*q)
{structstudent*p1,*p2;
longcount;
printf("请输入你要删除的学生学号:
");
scanf("%ld",&count);
p1=q;
while(count!
=p1->num&&p1->next!
=NULL)
{p2=p1;p1=p1->next;};
if(count==p1->num)
{if(p1==q)
q=p1->next;
else
p2->next=p1->next;
printf("delete:
%ld\n",p1->num);}
}
intmain(void)
{structstudent*head,*tail,*p,*p1,*p2,*q;
intn=0,i;
longnumber,NUM;
printf("请输入%d个学生的信息:
\n",N);
p=tail=(structstudent*)malloc(len);
head=NULL;
scanf("%ld%s",&p->num,p->name);
while(p->num!
=0)
{n+=1;
if(n==1)
head=p;
else
tail->next=p;
tail=p;
p=(structstudent*)malloc(len);
scanf("%ld%s",&p->num,p->name);};
tail->next=NULL;
printf("\n这10个学生的信息为:
\n");
p=head;
if(head!
=NULL)
do
{printf("%-15ld%-15s\n",p->num,p->name);
p=p->next;}while(p!
=NULL);
search(head);
q=head;
cdelete(q);
do
{printf("%-15ld%-15s\n",q->num,q->name);
q=q->next;}while(q!
=NULL);
}
4.运行结果:
五、知识点、难点及解决办法。
主要考察利用指针制作单向链表,难点在于各个结点的链接以及对于链表的输出,删除结点时如何不让链表断开
定义一个头指针和一个尾指针,通过尾指针的移动实现结点的链接,删除结点时先将要删除结点两端的结点链接上,再删除。
六、编程小结或体会。
制作单向链表是对指针的充分运用,可以节省内存,但是要熟练掌握还是有