版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
7与链一、1、2、3、4、5、6、7、8、9、10、12、13、14、15、16、17、18、19、20、21、二、填空1、C语言规定,结构体变量的输入、输出都是对结构体变量的成员2、对链表进行操作必须找到表头结点,因此设置 头结 专门存放其地址3、链表的基本操作包括:建立链表、输出链表、插入结点 删除结点4、对链表进行操作时必须先找到链表 结点三、阅读程序1、结果:t.x=1 t.s=“ 3、运行结果:4、fun的功能是:表首添加法建立一个链表输出结果:4 5、fun1fun2的功能是:输出链表运行结果:1 6、函数f1的功能:表尾添加法建立链表函数f2的功能:链表进行逆序函数f3的功能:输出链表运行结果 7、链表:2—>5—>9—>12—>四、编程1、编程实现从键盘输入3个人的信息(包括、和,再将这些信息输出显示,2个函数,并用指向结构体变量的指针实现。 voidinput(structman*p,int,{struct man*q;,printf("按顺序输入%d个人的for(;p<q;
:",scanf("%s%d%s",p->name,&p->age,p- }voidoutput(structman*p,int man*q;for(;p<q; %s\n",p->name,p->age,p- }voidmain( structman ,3); ,}2、设一个单位有30名员工,每个员工的信息包括:员工编号、、工资,请编程完成以下功能:(1)定义员工结构体类型;(2)输入每个员工的信息;(3)计算该单位员工的平均工资是多少;(4)输出那些工资高于平均工资的员工的。#include<stdio.h>#defineN30 intcharname[10];intpay;voidmain( for(i=0;i<N;i++)scanf("%d%s%d",&emp[i].num,emp[i].name,&emp[i].pay);for(i=0;i<N;i++) ave=ave+emp[i].pay;ave=ave/for(i=0;i<N;if(emp[i].pay> printf("%s\n",}3、设有40名学生,每个学生的信息包括:学号、、三门课成绩和平均分,请定义学生2个函数实现以下功能:输入5名学生的信息,计算平均分并输出每个学生的学号、和平均分#include<stdio.h>#defineN40struct // voidfun1(struct // i,j; for scanf("%d%s",&a[i].num,a[i].name);for(j=0;j<3; scanf("%f",&a[i].score[j]);}}for printf("%d%s%f\n",a[i].num,a[i].name,}voidfun2(struct inti,for(i=0;i<5;i++)if printf("%d,%s,",for(j=0;j<3;j++) printf("%f,",a[i].score[j]);printf("%f\n",a[i].ave);}}void structstudentstu[N];}4、设一个单位有300名员工,每个员工的信息包括:员工编号、、工资,请定义员工2个函数完成以下功能:按职工工资从高到低进行排序,并在main#include<stdio.h>#defineN300structwork wage;} input(struct intfloatave,sum=0;for(i=0;i<N;i++) scanf("%d%s%f",&a[i].num,a[i].name,&a[i].wage);}printf("平均工资=%f\n",} sort(struct // i,structworktemp;for(i=0;i<N-1;i++)for(j=0;j<N-i-1;j++) }voidmain({structwork for(intprintf("%d,%s,%f\n",w[i].num,w[i].name,}510个数据,要求将它们由小到大排序,然后输出排序后的数据并且输出每个数据原#defineN10structnumber voidmain( structnumber a[N],t; i,j;for(i=0;i<N; scanf("%d",&a[i].num);}for(i=0;i<N-1;for(j=0;j<N-1-i;if(a[j].num>a[j+1].num for(i=0;i<N;i++)printf("%3d%3d\n",a[i].num,a[i].order}3个函数实现。#defineN30typedefstruct{chardm[5];charma[12];floatdj;intnum;floatprice;voidinput(SELLa[],int{intprintf("请按产品代码(4位),产品名称(10位),单价,销售数量的顺序依次输入\n");for(i=0;i<n;i++) }}voidsort(SELLa[],int inti,j;if(strcmp(a[j].dm,a[i].dm)>0||(strcmp(a[j].dm,a[i].dm)==0&&a[j].price>a[i].price) SELL a[j]=temp;}voidoutput(SELLa[],int for(inti=0;i<n;printf("%4s,%10s,%.2f,%4d,}void SELLintscanf("%d",&n);input(s,sort(s,output(s,n);}70时结束,再将这些数按与输入相反的structnode{intstructnodevoid num,n=0; structnode printf("0时结束。\n");scanf("%d",&num); p=(structnode*)malloc(sizeof(structnode)); scanf("%d",} printf("%d\t",p->x); }}8、假设已有一个有序链表:1—>4—>6—>9,现输入一个整数n,如果n的值和链表中某 struct structnode *p,*q=NULL printf(“inputn:”); scanf(“%d”,&n);p=head;while((n!=p->num)&&(p->next!=NULL) if(n==p->num) if(p==head) (pprintf(“已删除该结点!} printf没有可删除的结点!\n”);return(head);}typedefstruct numstructnode*next sizeof(SD) SD *p1,*p2,*head=NULL; p1=(SD*)malloc(LEN);scanf("%d",&p1->num); if(i==1) p2->next=p1;p1=(SD*)malloc(LEN);scanf("%d",&p1-}p2->next=p1;return(head);} list(SD*head *p=head;while(p!=NULL) printf("%d\n",p- p=p->next } min(SD*head *p=head;intmin=p->num;while(p!=NULL p=p->next;}printf("theminnumberis%d\n",} main( h=creat();list(h);}10、设有一个有序链表(按成员a的值从小到大排序x,按其大小将它(3星)struct struct struct *insert(struct *head structpoint *p0,*p1,*p2; printf("inputx:");scanf("%d",&x)p0=(structpoint*)malloc(LEN);p0->a=x;if head=p0; p0->next=NULL;} while((p0->a>p1->a)&&(p1->next!=NULL) p2=p1; p1=p1->next; if(p0->a<=p1->a) if(head==p1) head=p0; p2->next=p0;p0->next=} p1- p0->next=NULL;}return(head)}11N个学生的信息,按总分从高到低对学生信息(3星)structnode num; scorestructnode*next sizeof(structnode) structnode*insert(structnode*head struct *p0,*p1,*p2p0=(structnode*)malloc(LEN);//p0指向产生的新结点 //p0指针成员赋NULLscanf("%d%d",&p0->num,&p0 //if( head= //链表为空时,令head while((p0->score<p1->score)&&(p1- p1=p1->next; if(p0->score>=p1->score) if( //
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 长春大学旅游学院《语言治疗学》2025-2026学年期末试卷
- 阜阳科技职业学院《文学批评》2025-2026学年期末试卷
- 2026年苏教版小学三年级语文上册基础巩固拓展卷含答案
- 2026年人教版小学四年级数学上册数学广角优化问题卷含答案
- 深度解析(2026)《GBT 4207-2022固体绝缘材料耐电痕化指数和相比电痕化指数的测定方法》
- 2026年人教版小学六年级数学下册圆锥体积应用卷含答案
- 深度解析(2026)《GBT 3871.16-2006农业拖拉机 试验规程 第16部分:轴功率测定》
- 深度解析(2026)《GBT 3758-2008卡套式管接头用锥密封焊接接管》
- 深度解析(2026)《GBT 3159-2008液压式万能试验机》
- 2026年人教版初中九年级语文下册中考综合性学习专题卷含答案
- 教辅编辑笔试试题及答案
- 慢性阻塞性肺疾病诊治指南(2021年修订版)
- 2024-2025学年浙教版八年级数学下册期中测试卷 第1~4单元(浙江专用)(含答案)
- 湖南事业单位考试a类试卷及答案
- 四川省宜宾市2025年中考化学模拟试卷(附答案)
- 患者出入院管理
- 工业机器人集成应用(ABB) 高级 课件全套 项目1-5 工业机器人系统集成设计 -工业机器人生产线系统集成
- 生成式人工智能时代文化传播特征、困境与路径选择
- 《自动化生产线安装与调试》课程标准
- DLT 593-2016 高压开关设备和控制设备
- 恒生估值业务手册
评论
0/150
提交评论