【练习】编写在带头节点的单链表L中删除最小值节点的算法,假设最小值节点只有一个

题目:

编写在带头节点的单链表L中删除最小值节点的算法,假设最小值节点只有一个。

思路: 

用p从头至尾扫描单链表,pre指向p结点的前驱,用minp保存值最小的结点指针(初值为p),minpre指向*minp结点的前驱(初值为pre)。一边扫描,一边比较,若p->data小于minp->data,则将p、pre分别赋值给minp、minpre,如下图所示。当p扫描完毕时,minp指向最小值结点,minpre指向最小值结点的前驱结点,再将minp所指结点删除即可。

代码: 

LinkList DeleteMin(LinkList &L) {
  LNode*pre=L,*p=pre->next; //p为工作指针,pre指向其前驱
  LNode *minpre=pre,*minp=p; //保存最小值结点及其前驱
  while(p!=NULL){
    if (p->data<minp->data){ //找到比之前找到的最小值结点更小的结点
      minp=p;
      minpre=pre;
    }
  pre=p;
  p=p->next;//继续扫描下一个结点
  }
  minpre->next=minp->next;
  free (minp); //删除最小值结点
  return L;
}

考察内容:

单链表

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值