这段代码不能看懂,请问怎么理解
//总分排序
void Sort(pnode phead)
{
pnode p, q;//定义两个指针
node temp;
for(p=phead->pnext;NULL!=p;p=p->pnext)
{
for(q=p->pnext;NULL!=q;q=q->pnext)
{
if(p->st.Totalst.Total)//当前一个学生的总分小于后一个学生的总分时
{
temp.st=p->st;//交换学生的位置
p->st=q->st;
q->st=temp.st;
}
}
}
}
c语言链表排序代码理解
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- it_hao528 2022-07-13 12:25关注
这是选择排序,用p->st.Totalst.Total依次和q->st.Totalst.Total进行比较进行排序。
你这个if判断条件应该是if(p->st.Totalst.Total < q->st.Totalst.Total)吧
最终的排序结果是学生的总分从大到小的顺序。
如果还有不懂的,可以沟通解决哈!本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 爬虫爬取网站的一些信息
- ¥15 关于vue2中methods使用call修改this指向的问题
- ¥15 idea自动补全键位冲突
- ¥15 请教一下写代码,代码好难
- ¥15 iis10中如何阻止别人网站重定向到我的网站
- ¥15 滑块验证码移动速度不一致问题
- ¥15 Utunbu中vscode下cern root工作台中写的程序root的头文件无法包含
- ¥15 麒麟V10桌面版SP1如何配置bonding
- ¥15 Marscode IDE 如何预览新建的 HTML 文件
- ¥15 K8S部署二进制集群过程中calico一直报错