LEETCODE submissions

选择排序法(通过交换指针对应的VAL值,查找最小的值的方法实现了链表的选择排序)
选取第一个元素作为枢纽元的版本,因为链表选择最后一元素需要遍历一遍(第一个元素确定后指针开始后移开始对第二个数进行操作)
/**

  • Definition for singly-linked list.
  • struct ListNode {
  • int val;
    
  • ListNode *next;
    
  • ListNode(int x) : val(x), next(NULL) {}
    
  • };
    /
    Solution {
    public:
    ListNode
    insertionSortList(ListNode* head) {
    if(head == NULL || head->next == NULL)return head;
    ListNodefront=head->next; //定义一个快指针;
    ListNode
    p=head;
    int temp;
    ListNode*flag=head; //将flag指针作为目标指针
    while(flag->next!=NULL){
    while(front!=NULL)
    {
    if(p->val > front->val) // 寻找链表中的最小的值,保留其指针
    {
    p=front;
    }
    front=front->next;
    }
    swap(p->val,flag->val); //将最小的值放在head的第一个位置
    front=flag->next; //将指针下移开始查找链表中的第二小的值的指针,以此类推
    p=flag->next;
    flag=flag->next;
    }
    return head; //返回head;
    }

};

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值