《C语言程序设计》综合实习报告_第1页
《C语言程序设计》综合实习报告_第2页
《C语言程序设计》综合实习报告_第3页
《C语言程序设计》综合实习报告_第4页
《C语言程序设计》综合实习报告_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、用指针优化学生成绩排名一、目的1 .熟悉变量的指针和指向变量的的指针变量的概念和使用2 .熟悉数组的指针和指向数组的的指针变量的概念和使用3 .掌握冒泡法或选择法排序的算法4 .掌握函数的定义、调用、声明,以及参数的两种传递方式二、实习环境个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC+等编译开发环境三、实习内容与步骤1 .定义一个数组stu10存放10个学生的成绩,从键盘输入数据,要求用指针实现2 .将数组stu10的内容输出到屏幕上,要求用指针实现3 .将成绩数组按照从高到低进行排序,要求用指针实现4 .将第三步内容放在函数中实现,在主函数中调用实现排序

2、,用指针实现,输出排序后的成绩单5 .采用指针方法,输入字符串“studentscore",复制该字符串并输出(复制字符串采用库函数或用户自定义函数)6 .在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段运行结果(屏幕截图)。7 .在实习报告中说明知识点。8 .在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。四、程序流程图、算法及运行结果1 .程序流程图:开始由键盘输入成绩输出成绩比较成绩的高低复制student输出字符串输出排序好的成绩对成绩排序结束2 .算法:先定义一个函数接收10个学生的成绩,利用指针将数据保存在数组中,再定义第二个函数输出所以学生的

3、成绩,同样也是使用指针,最后定义一个函数用选择排序法对成绩进行由大到小的排序,将指针指向的是数组中的第一个地址,在主函数中依次调用这两个函数;定义一个字符指针指向字符stc利用库函数中的strcpy将studentscore复制给字符指针,输出字符串3 .程序:#include"stdio.h"#include"string.h"structstudentintgrade;intnum;stu10;voidinput(structstudent*p)inti;for(i=0;i<10;i+,p+)printf("请输入第-2d个学生的成绩

4、:”,i+1);scanf("%d%d",&p->num,&p->grade);voidprintout(structstudent*p)inti;for(i=0;i<10;i+,p+)printf("第%-2d个学生的成绩为:%dn",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;

5、i<10;i+)for(j=0;j<10-i;j+)if(stuj.grade<stuj+1.grade)arrow(&stuj.num,&stuj+1.num,&stuj.grade,&stuj+1.grade);intmain(void)structstudentstu10,*ptr;inti;charstring100,*s;s=string;ptr=stu;input(ptr);printout(ptr);place(stu);printf("排序后的成绩单为:n");for(i=0;i<10;i+)print

6、f("第%-2d名%-2d%-5dn",i+1,stui.num,stui.grade);printf("n");strcpy(s,"studentscore");printf("%sn",string);4.运行结果:2910主贝 8 7 56567232 去口 98377543 59欣:;学成成成成成成成成成一生绩绩绩绩绩糜 挈成成成成成成成成成翻 .- L - - J_ a 1.- - -14二 1.- - -14二fa=-JJ 二=-贝 10生差生生生生差生增8276563752998775543 3011

7、24569738一名名名名名名名名名H12 34-5678 91 序 123 4567891 第第第第MM第第第膏tudentscore五、知识点、难点及解决办法。主要考察的是利用指针作为函数参数以及指针数组的知识点,如何使指针指向数组并能将值返回给主函数是一个难点首先定义一个整型指针指向数组stu口的首地址,在自定义函数中运用循环结构实现指针的移动并分别存储各个学生的成绩返回给主函数六、编程小结或体会。编程时除了注意指针与函数如何调用外,还要注意细节问题,比如自定义变量类型的统一,循环结构的循环次数等等,要谨慎对待课题二:学生成绩单制作一、目的1 .掌握结构体变量及数组的定义、赋值、初始化、

8、输入、输出2 .结构体数组的操作。二、实习环境个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC+等编译开发环境三、实习内容与步骤1 .定义一个结构体数组,存放10个学生的学号,姓名,三门课的成绩2 .从键盘输入10个学生的以上内容3 .输出单门课成绩最高的学生的学号、姓名、以及该门课程的成绩4 .输出三门课程的平均分数最高的学生的学号、姓名及其平均分5 .将10个学生按照平均分数从高到低进行排序,输出结果,格式如下所示:numbernamemathChineseEnglishaverage103tom909010095101alice908070806 .在实

9、习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。7 .在实习报告中说明知识点。8 .在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会四、程序流程图、算法及运行结果1 .程序流程图:比较每个学生单门课成绩计算每个学生平均分比较按平均分高低排序根据返回值输出相应的学生信息按照排序输出学生信息结束2先定义一个结构体,存储学生的各项信息,定义一个结构体指针指向结构体数组,第一个函数比较每个学生单门课的成绩,返回每一门课最高分学生的stu的下标;第二个函数比较每个学生的平均分,返回平均分最高的学生;第三个函数主要按照平均分高低对学生进行排序,通过循环和选择排

10、序法实现指针的移动以及重新排列,主函数中依次调用这三个函数3.程序:#include"stdio.h"#defineN10structstudentlongnumber;charname20;floatgrade3;floataverage;stu10;inthanshu_best(structstudent*p,intm)intq,num;floata;a=p->gradem;num=0;for(q=0;q<N-1;q+)if(p+q)->gradem>a)a=(p+q)->gradem;num=q;returnnum;inthanshu_a

11、verage(structstudent*p)inti,m,index;floata;for(m=0;m<N;p+,m+)p->average=0;for(i=0;i<3;i+)p->average=p->average+p->gradei;p->average=p->average*1.0/3;a=p->average;for(m=0;m<N;p+,m+)if(p->average>a)a=p->average;index=m;elseindex=0;returnindex;voidhanshu_place(str

12、uctstudentstu)inti,j;structstudentt;for(i=0;i<N;i+)for(j=i;j<N-1;j+)if(stuj+1.average>stui.average)t=stuj+1;stuj+1=stui;stui=t;voidmain()structstudentstu10,*ptr;inti,j,index,m,num;floataverage;ptr=stu;for(i=0;i<N;i+)printf("请输入第d4"学生的学号、姓名及三科成绩:n”,i+1);scanf("%ld%s",&

13、amp;stui.number,);for(j=0;j<3;j+)scanf("%f",&stui.gradej);printf("n");for(m=0;m<3;m+)num=hanshu_best(ptr,m);printf("学号%ld姓名:%-10s最高分%-8.2fn",stunum.number,,stunum.gradem);index=hanshu_average(ptr);printf("n三门课平均分最高的学生信息是:n");print

14、f("学号ld姓名:-10s平分-8.2fn”,stuindex.number,,stuindex.average);printf("n10个学生由高分到低分排名为:n");printf("numbernameMathChineseEnglishaveragen");hanshu_place(ptr);for(i=0;i<N;i+)printf("%-10ld%-10s%",stui.number,);for(j=0;j<3;j+)printf("%-10.2

15、f',stui.gradej);printf("%-10.2fn",stui.average);4.运行结果:,第9个学生白序号.姓名及三科成绩:090xin94928243MM lu名名名 姓姓姓 0 0 09 9 9高高高日BT取番输入第10个学生的学号、姓名及三科成绩Fanghuannchenhuang chen502080tao73.00眄个学生由高分到低分排名为: minber name Math73.0072.006Mshao93.BB30uang32.0040XU38.00108lu97.0070Ehao 78.00.,0042.00EnglishB7

16、,00B2 .MUG3 .U092 .&&82.9046 .0043,0048. MMB4.0067.QQ五、知识点、难点及解决办法。主要考察的是结构体指针的运用,比较难的地方也就是如何将指针指向结构体并返回我们所要的数值先定义一个结构体数组,再定义一个结构体指针,令指针指向数组的首地址,在自定义函数中通过指针的运算实现数组的运算,并返回相应的值六、编程小结或体会。在输出我们所需要的数据时候可以通过一些小技巧使程序看起来更好看。掌握结构体指针的技巧可以解决很多问题,使自己的程序具有解决多个复杂问题的能力,以后多练习此类的程序设计问题,使自己更加熟练课题三:学生成绩文件管理一、目

17、的1 .掌握文件指针的概念和运用2 .掌握文件的相关操作:打开、读、写、关闭3 .掌握文件的定位操作二、实习环境个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC+将编译开发环境三、实习内容与步骤1 .定义一个结构体数组,存放10个学生的学号,姓名,三门课的成绩2 .从键盘输入10个学生的以上内容,存入文件stud.txt,关闭文件3 .打开stud.txt文件,将数据读出,查看是否正确写入,关闭文件。4 .打开文件stud.txt文件,读出数据,将10个学生按照平均分数从高到低进行排序,分别将结果输出到屏幕上和另一文件studsort.txt中。5 .在实习报

18、告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。6 .在实习报告中说明知识点。7 .在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。四、程序流程图、算法及运行结果1 .程序流程图:开始键入每个学生的信息将排序后的信息存入另T文件按平均分高低排序T 将文件中的信息读出将学生信息存入文件中2 .算法:首先创建一个可读可写的新文件stud.txt,键入十个学生的信息并储存在文件中,关闭程序;打开文件stud.txt,读出文件中的信息并输出,检查有无错漏,并按照平均分通过选择排序法对学生由高到低排序,关闭程序;将排好序的信息输出并存储在新的可写文件studs

19、ort.txt中3 .程序:#include"stdio.h"#include"stdlib.h"#defineN10structstudentlongnum;charname20;intgrade3;stu10;intmain(void)FILE*fp,*fpp;structstudentstu10,t;floataverage100;inti=0,j;if(fp=fopen("stud.txt","w+")=NULL)printf("该文件打开失败!");exit(0);for(i=0;i&

20、lt;N;i+)printf("第%-2d个学生的学号、姓名及三门课成绩:n",i+1);scanf("%ld%s",&stui.num,);fprintf(fp,"第-2个学生的学号、姓名及三门课成绩:n",i+1);fprintf(fp,"%ld%-5s",stui.num,);for(j=0;j<3;j+)scanf("%d",&stui.gradej);fprintf(fp,"%d",stui.gradej);

21、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<N;i+)n",i+1);printf("第学生的学号、姓名及三门课成绩:fscanf(fp,"%ld%s",&stui.num,stui.n

22、ame);printf("%ld%-5s",stui.num,);for(j=0;j<3;j+)fscanf(fp,"%d",&stui.gradej);printf("%d",stui.gradej);printf("n");if(fclose(fp)printf("该文件无法正常关闭!n");exit(0);if(fp=fopen("stud.txt","r+")=NULL)printf("该文件打开失败!&q

23、uot;);exit(0);for(i=0;i<N;i+)fscanf(fp,"%ld%s",&stui.num,);for(j=0;j<3;j+)fscanf(fp,"%d",&stui.gradej);for(i=0;i<N;i+)for(j=0;j<3;j+)averagei=averagei+stui.gradej;averagei=averagei*1.00/3;for(i=0;i<N-1;i+)for(j=i;j<N;j+)if(averagej+1>averagei

24、)t=stuj+1;stuj+1=stui;stui=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<N;i+)printf("%ld%-5s",stui.num,);fprintf(fpp,"%ld%-5s&

25、quot;,stui.num,);for(j=0;j<3;j+)fprintf(fpp,"%d",stui.gradej);printf("%d",stui.gradej);printf("n");fprintf(fpp,"n");if(fclose(fp)printf("该文件无法正常关闭!n");exit(0);4 .运行结果:"studsruxt-记事本文件图员事图画董看M能面面tLUfang丸冢E7110chenS97G79113hu797686112s

26、haa796SE7117XU379S87113liu799878116huangT?6B7E115lin9287E1.14zhaa787E68119taQ271262奉S苫生的学号、延名及三门课嫌:114Zhao?87B69第6个学生的学号、姓名及三门课成绩:115lin972B78第7个学生的学号、姓名及三门课成绩:116huang7968?8六8个学生的学号、姓名及三门课成绩:117xu379B87第9个学生的学号、姓名及三门课成绩:萤,翟生裔学集提名及三门课成绩:119tao2?7262由高到低排序为1:111Fdng989087J1Mchen897B79118hu797686112sh

27、ao79685711?XU379887113liu7998?8116huang796E78115lin972B7311,zhao78?e68119tao277262一Jstud.H-记事本1文件旧编磋查言曳)津刖口第1个学生的学号、姓名及三门课城.110chenS97SE第2个学生的学号、姓名及三门课成馈,Lilfang9S90ST第3个学生的学号、姓名及三门课席:112shg796857第4个学生的学号、姓名及三门课成绩:113liu799878第5个学生的学号、姓名及三门课成绩:114zhao7873CE第6个学生的学号、姓名及三门课成绩115lin盟羽7S第7个学生的学号、姓名及三门课成

28、接116huang'rS6S7S第2个学生的学号、姓名及三门课席117xu379587第9个学生的学号、姓名及三门课成绩:118hu797686第学生的学号、姓名及三门课成绩:119tao27T262五、知识点、难点及解决办法。主要考察对于文件信息的存储以及读取文件内的信息,难点在于如何将信息存储起来以及如何从文件中读取有效信息并显示在调式框中首先定义一个指针指向文件,然后创建或是打开一个的文件,注意文件的类型和打开方式,如果是写入信息则用fprintf,如果是读取信息则是fscanf,注意写入和读取的书写格式,前面许注明指向该文件的指针六、编程小结或体会。通过文件的学习,以后调试程序

29、后还可以将信息永久的保存起来随时使用或更改,不需要使用一次就输入一次,方便又省时间,课题四:链表的创建与使用、目的1.掌握单向链表的概念2,掌握单向链表的创建、查找、删除方法二、实习环境个人计算机,Windows操作系统,TurboC2.0或WinTC或VisualC+将编译开发环境三、实习内容与步骤1 .创建一个单向链表,存放10个学生的学号,姓名,并输出这种10个学生的信息。2 .在链表中查找指定学号的学生,输出其姓名。3 .在链表中删除指定学号的学生,然后输出其余学生的信息。4 .在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。5 .在实习报告中说明知

30、识点。6 .在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。四、程序流程图、算法及运行结果1 .程序流程图:1T删除指定学号的学生输出该学生姓名输出其余学生信息2 .算法:用指针处理单向链表,定义一个头指针,尾指针,通过尾指针的移动实现数据信息的存储与读取;删除结点时,应该先将要删除结点前后的结点连上,然后再将其删除,保证链表不会“断”。3 .程序:#include"stdio.h"#include"stdlib.h"#defineN10#definelensizeof(structstudent)structstudentlongnum

31、;charname20;structstudent*next;voidsearch(structstudent*head)longnumber;structstudent*p;p=head;printf("请输入要查找的学生学号:");scanf("%ld",&number);doif(p->num=number)printf("%-15sn",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

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论