[数据结构]分隔链表(leetcode725)c++

分隔链表(leetcode725)c++

在这里插入图片描述

https://leetcode-cn.com/problems/split-linked-list-in-parts/

    //如果链表有N个结点,则分隔的链表中每个部分中都有n/k个结点,且前N%k部分有一个额外的结点。
    //对于每个部分,有 width + (i < rem ? 1 : 0) 个结点

    //首先计算得长度,每个部分的宽度
    //然后创建vector
    //最后直接拆分原链表,把新链表存入vector中
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    vector<ListNode*> splitListToParts(ListNode* root, int k) {
        //如果链表有N个结点,则分隔的链表中每个部分中都有n/k个结点,且前N%k部分有一个额外的结点。
        //对于每个部分,有 width + (i < rem ? 1 : 0) 个结点

        //首先计算得长度,每个部分的宽度
        //然后创建vector
        //最后直接拆分原链表,把新链表存入vector中

        //--[1]--
        ListNode *p;
        p=root;
        int len=0;
        while(p){
            len++;
            p=p->next;
        }
        int width = len / k, remainder= len % k;
        //~

        //--[2]--
        std:: vector <ListNode *> node_vec;
        //~

        //--[3]--
        p=root;
        for(int i=0; i<k; i++){
            ListNode *new_head=p;
            for(int j=1; j<width+(i<remainder?1:0); j++){
                if(p){
                    p=p->next;
                }
            }

            if(p){
                ListNode *pre=p;
                p=p->next;
                pre->next=nullptr;
            }

            node_vec.push_back(new_head);
        }
        //~        

        //--[4]--
        return node_vec;
        //~
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值