欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    C语言知识程序设计-综合实习报告.doc

    • 资源ID:2754959       资源大小:333.03KB        全文页数:17页
    • 资源格式: DOC        下载积分:8金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    C语言知识程序设计-综合实习报告.doc

    课题一:用指针优化学生成绩排名一、目的1熟悉变量的指针和指向变量的的指针变量的概念和使用2熟悉数组的指针和指向数组的的指针变量的概念和使用3. 掌握冒泡法或选择法排序的算法4. 掌握函数的定义、调用、声明,以及参数的两种传递方式二、实习环境个人计算机,Windows操作系统,Turbo C 2.0或 WinTC或Visual C+等编译开发环境三、实习内容与步骤1定义一个数组stu10存放10个学生的成绩,从键盘输入数据,要求用指针实现2将数组stu10的内容输出到屏幕上,要求用指针实现3将成绩数组按照从高到低进行排序,要求用指针实现4将第三步内容放在函数中实现,在主函数中调用实现排序,用指针实现,输出排序后的成绩单5采用指针方法,输入字符串“student score ”,复制该字符串并输出(复制字符串采用库函数或用户自定义函数)6在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段运行结果(屏幕截图)。7. 在实习报告中说明知识点。8在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。四、程序流程图、算法及运行结果1.程序流程图:开始由键盘输入成绩输出成绩比较成绩的高低复制student score对成绩排序输出字符串输出排序好的成绩结束2.算法:先定义一个函数接收10个学生的成绩,利用指针将数据保存在数组中,再定义第二个函数输出所以学生的成绩,同样也是使用指针,最后定义一个函数用选择排序法对成绩进行由大到小的排序,将指针指向的是数组中的第一个地址,在主函数中依次调用这两个函数;定义一个字符指针指向字符串,利用库函数中的strcpy将student score复制给字符指针,输出字符串3.程序:#include"stdio.h"#include"string.h"struct studentint grade;int num;stu10;void input(struct student *p) int i;for(i=0;i<10;i+,p+) printf("请输入第 %-2d个学生的成绩:",i+1);scanf("%d%d",&p->num,&p->grade); void printout(struct student *p) int i;for(i=0;i<10;i+,p+)printf("第 %-2d个学生的成绩为:%dn",i+1,p->grade);void arrow (int *p1,int *p2,int *px,int *py) int t,m; t=*px; *px=*py; *py=t;m=*p1; *p1=*p2; *p2=m; void place(struct student stu) int i,j; for(i=1;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); int main(void) struct student stu10,*ptr;int i;char string100,*s;s=string;ptr=stu;input(ptr);printout(ptr);place(stu);printf("排序后的成绩单为:n");for(i=0;i<10;i+) printf("第 %-2d名 %-2d %-5dn",i+1,stui.num,stui.grade);printf("n"); strcpy(s,"student score");printf("%sn",string);4.运行结果:五、知识点、难点及解决办法。主要考察的是利用指针作为函数参数以及指针数组的知识点,如何使指针指向数组并能将值返回给主函数是一个难点首先定义一个整型指针指向数组stu的首地址,在自定义函数中运用循环结构实现指针的移动并分别存储各个学生的成绩返回给主函数六、编程小结或体会。编程时除了注意指针与函数如何调用外,还要注意细节问题,比如自定义变量类型的统一,循环结构的循环次数等等,要谨慎对待课题二:学生成绩单制作一、目的1掌握结构体变量及数组的定义、赋值、初始化、输入、输出2结构体数组的操作。二、实习环境个人计算机,Windows操作系统,Turbo C 2.0或 WinTC或Visual C+等编译开发环境三、实习内容与步骤1定义一个结构体数组,存放10个学生的学号,姓名,三门课的成绩2从键盘输入10个学生的以上内容3输出单门课成绩最高的学生的学号、姓名、以及该门课程的成绩4输出三门课程的平均分数最高的学生的学号、姓名及其平均分5将10个学生按照平均分数从高到低进行排序,输出结果,格式如下所示:number name math Chinese English average103 tom 90 90 100 95101 alice 90 80 70 80 6在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。7在实习报告中说明知识点。8在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会四、程序流程图、算法及运行结果1.程序流程图:比较每个学生单门课成绩计算每个学生平均分比较按平均分高低排序结束开始键入每个学生的信息根据返回值输出相应的学生信息按照排序输出学生信息2.算法:先定义一个结构体,存储学生的各项信息,定义一个结构体指针指向结构体数组,第一个函数比较每个学生单门课的成绩,返回每一门课最高分学生的stu的下标;第二个函数比较每个学生的平均分,返回平均分最高的学生;第三个函数主要按照平均分高低对学生进行排序,通过循环和选择排序法实现指针的移动以及重新排列,主函数中依次调用这三个函数3.程序:#include"stdio.h"#define N 10struct studentlong number;char name20;float grade3; float average;stu10;int hanshu_best(struct student *p,int m) int q,num;float a;a=p->gradem;num=0;for(q=0;q<N-1;q+)if(p+q)->gradem>a) a=(p+q)->gradem; num=q; return num;int hanshu_average(struct student *p) int i,m,index;float a;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;return index;void hanshu_place(struct student stu) int i,j; struct student t;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;void main()struct student stu10,*ptr;int i,j,index,m,num;float average;ptr=stu;for(i=0;i<N;i+) printf("请输入第%d个学生的学号、姓名及三科成绩:n",i+1); scanf("%ld%s",&stui.number,stui.name);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.name,stunum.gradem); index=hanshu_average(ptr); printf("n三门课平均分最高的学生信息是:n"); printf("学号%ld 姓名:%-10s 平均分%-8.2fn",stuindex.number,stuindex.name,stuindex.average); printf("n10个学生由高分到低分排名为:n");printf("number name Math Chinese English averagen");hanshu_place(ptr);for(i=0;i<N;i+) printf("%-10ld%-10s%",stui.number,stui.name); for(j=0;j<3;j+)printf("%-10.2f",stui.gradej);printf("%-10.2fn",stui.average);4.运行结果:五、知识点、难点及解决办法。 主要考察的是结构体指针的运用,比较难的地方也就是如何将指针指向结构体并返回我们所要的数值 先定义一个结构体数组,再定义一个结构体指针,令指针指向数组的首地址,在自定义函数中通过指针的运算实现数组的运算,并返回相应的值六、编程小结或体会。在输出我们所需要的数据时候可以通过一些小技巧使程序看起来更好看。掌握结构体指针的技巧可以解决很多问题,使自己的程序具有解决多个复杂问题的能力,以后多练习此类的程序设计问题,使自己更加熟练课题三:学生成绩文件管理一、目的1掌握文件指针的概念和运用2掌握文件的相关操作:打开、读、写、关闭3掌握文件的定位操作二、实习环境个人计算机,Windows操作系统,Turbo C 2.0或 WinTC或Visual C+等编译开发环境三、实习内容与步骤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"#define N 10struct studentlong num;char name20;int grade3;stu10;int main(void) FILE *fp,*fpp; struct student stu10,t;float average100;int i=0,j;if(fp=fopen("stud.txt","w+")=NULL) printf("该文件打开失败!"); exit(0); for(i=0;i<N;i+) printf("第 %-2d个学生的学号、姓名及三门课成绩:n",i+1);scanf("%ld%s",&stui.num,stui.name);fprintf(fp,"第%-2d个学生的学号、姓名及三门课成绩:n",i+1);fprintf(fp,"%ld %-5s",stui.num,stui.name);for(j=0;j<3;j+) scanf("%d",&stui.gradej);fprintf(fp,"%d ",stui.gradej); 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+) printf("第%d个学生的学号、姓名及三门课成绩:n",i+1);fscanf(fp,"%ld%s",&stui.num,stui.name);printf("%ld %-5s",stui.num,stui.name);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("该文件打开失败!");exit(0); for(i=0;i<N;i+) fscanf(fp,"%ld%s",&stui.num,stui.name);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) 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,stui.name);fprintf(fpp,"%ld %-5s",stui.num,stui.name);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.运行结果:五、知识点、难点及解决办法。 主要考察对于文件信息的存储以及读取文件内的信息,难点在于如何将信息存储起来以及如何从文件中读取有效信息并显示在调式框中 首先定义一个指针指向文件,然后创建或是打开一个的文件,注意文件的类型和打开方式,如果是写入信息则用fprintf,如果是读取信息则是fscanf,注意写入和读取的书写格式,前面许注明指向该文件的指针六、编程小结或体会。 通过文件的学习,以后调试程序后还可以将信息永久的保存起来随时使用或更改,不需要使用一次就输入一次,方便又省时间,课题四:链表的创建与使用一、目的1掌握单向链表的概念2掌握单向链表的创建、查找、删除方法二、实习环境个人计算机,Windows操作系统,Turbo C 2.0或 WinTC或Visual C+等编译开发环境三、实习内容与步骤1创建一个单向链表,存放10个学生的学号,姓名,并输出这种10个学生的信息。2在链表中查找指定学号的学生,输出其姓名。 3在链表中删除指定学号的学生,然后输出其余学生的信息。4在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。5在实习报告中说明知识点。6在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。四、程序流程图、算法及运行结果1.程序流程图:键入10个学生的信息开始结束主函数创建链表将学生信息存储进去查找指定学号的学生删除指定学号的学生输出其余学生信息输出该学生姓名2.算法: 用指针处理单向链表,定义一个头指针,尾指针,通过尾指针的移动实现数据信息的存储与读取;删除结点时,应该先将要删除结点前后的结点连上,然后再将其删除,保证链表不会“断”。3.程序:#include"stdio.h"#include"stdlib.h"#define N 10#define len sizeof(struct student)struct studentlong num;char name20; struct student *next;void search(struct student *head) long number;struct student *p;p=head;printf("请输入要查找的学生学号:");scanf("%ld",&number);do if(p->num=number)printf("%-15sn",p->name); p=p->next; while(p!=NULL);void cdelete(struct student *q) struct student *p1,*p2; long count;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;elsep2->next=p1->next; printf("delete :%ldn",p1->num); int main(void) struct student *head,*tail,*p,*p1,*p2,*q; int n=0,i;long number,NUM;printf("请输入%d个学生的信息:n",N); p=tail=(struct student *)malloc(len);head=NULL;scanf("%ld%s",&p->num,p->name);while(p->num!=0) n+=1;if(n=1)head=p;elsetail->next=p;tail=p;p=(struct student *)malloc(len);scanf("%ld%s",&p->num,p->name); ;tail->next=NULL; printf("n这10个学生的信息为:n"); p=head;if(head!=NULL)do printf("%-15ld%-15sn",p->num,p->name); p=p->next; while(p!=NULL); search(head); q=head;cdelete(q);do printf("%-15ld%-15sn",q->num,q->name); q=q->next; while(q!=NULL);4.运行结果:五、知识点、难点及解决办法。 主要考察利用指针制作单向链表,难点在于各个结点的链接以及对于链表的输出,删除结点时如何不让链表断开 定义一个头指针和一个尾指针,通过尾指针的移动实现结点的链接,删除结点时先将要删除结点两端的结点链接上,再删除。六、编程小结或体会。 制作单向链表是对指针的充分运用,可以节省内存,但是要熟练掌握还是有

    注意事项

    本文(C语言知识程序设计-综合实习报告.doc)为本站会员(一***)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开