写一子函数,实现动态建立链表,输入学号为001、002、003的3个同学的信息:学号,姓名,三门课成绩,平均分,当输入学号为0时结束建立链表
写一子函数,以上述链表作为实参,要求实现检索并返回成绩最高的同学信息指针
在主函数中使用函数指针实现子函数的调用,并输出“成绩最高的学生姓名+is the best”。
用c语言或c++写一程序
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- CSDN专家-sinJack 2022-06-14 20:15关注
#include <stdio.h> #include <stdlib.h> typedef struct _linknode { int num; char name[20]; int score[3]; float avg; struct _linknode *next; }linknode,*linklist; void creat(linklist head) { linklist q = head; linklist p = NULL;; int i=0; while(true) { p = (linklist)malloc(sizeof(linknode)); scanf("%d",&p->num); if(p->num==0){ break; } scanf("%s%d%d%d",p->name,&p->score[0],&p->score[1],&p->score[2]); p->avg = (p->score[0] + p->score[1]+p->score[1])/3.0; p->next = NULL; q->next = p; q = p; } } linklist LinkListSort(linklist head) { float avg=head->next->avg; linklist res=head->next,p = head->next; while (p->next!=NULL) { p=p->next; if(avg<p->avg){ avg=p->avg; res=p; } } return res; } int main() { linklist head = (linklist)malloc(sizeof(linknode)); linklist p = NULL,h; head->next = NULL; creat(head); h = LinkListSort(head); if(h!=NULL) printf("%s is the best",h->name); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 stm32开发clion时遇到的编译问题
- ¥15 lna设计 源简并电感型共源放大器
- ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
- ¥15 Vue3地图和异步函数使用
- ¥15 C++ yoloV5改写遇到的问题
- ¥20 win11修改中文用户名路径
- ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
- ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
- ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
- ¥15 帮我写一个c++工程