pMove=head;
while(pMove!=NULL)
{
strcpy(i,pMove->clas);
strcpy(j,pMove->next->clas);
if(strcmp(i,j)>0)
{
strcpy(na,i);
strcpy(i,j);
strcpy(j,na);
}
pMove=pMove->next;
}
pMove=head;
while (pMove != NULL)
{
printf("%5s%5s%20s%5s%20s%20s%20s%10s\n", pMove->name, pMove->sex, pMove->major,
pMove->clas, pMove->birthday, pMove->stu_code, pMove->id_code, pMove->enyear);
pMove = pMove->next;
}
这个给链表排序为什么是错的?如何修改
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- qzjhjxj 2022-01-10 19:44关注
修改调试通过,带头结点链表,供参考:
#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct dat { char name[5]; char sex[5]; char majo[20]; char clas[5]; char birthday[20]; char stu_code[20]; char id_code[20]; char enyear[10]; }Data; typedef struct lnode { Data data; struct lnode* next; }LNode; void sort(LNode *head) { LNode* pMove = head->next, * pNext = NULL; Data na; while(pMove) { pNext = pMove->next; while (pNext != NULL) { if (strcmp(pMove->data.clas, pNext->data.clas) > 0) { na = pMove->data; pMove->data = pNext->data; pNext->data = na; } pNext = pNext->next; } pMove = pMove->next; } pMove = head->next; while (pMove != NULL) { printf("%5s%5s%20s%5s%20s%20s%20s%10s\n", pMove->data.name, pMove->data.sex, pMove->data.majo,pMove->data.clas, pMove->data.birthday, pMove->data.stu_code, pMove->data.id_code, pMove->data.enyear); pMove = pMove->next; } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 PADS Logic 原理图
- ¥15 PADS Logic 图标
- ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
- ¥20 气象站点数据求取中~
- ¥15 如何获取APP内弹出的网址链接
- ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
- ¥50 STM32单片机传感器读取错误
- ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)
- ¥15 机器人轨迹规划相关问题
- ¥15 word样式右侧翻页键消失