kristimn 2022-07-13 12:04 采纳率: 100%
浏览 26
已结题

c语言链表排序代码理解

这段代码不能看懂,请问怎么理解
//总分排序
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;
}
}
}
}

  • 写回答

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)吧
    最终的排序结果是学生的总分从大到小的顺序。
    如果还有不懂的,可以沟通解决哈!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 7月21日
  • 已采纳回答 7月13日
  • 创建了问题 7月13日

悬赏问题

  • ¥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一直报错