题解 | #链表中的节点每k个一组翻转#

链表中的节点每k个一组翻转

http://www.nowcoder.com/practice/b49c3dc907814e9bbfa8437c251b028e

/**
    1、先求链表的长度,通过len / k算出要反转多少段
    2、进行每段反转,每段的头结点通过反转之后  还为下一段的头结点 需要记录每段的头结点

/*
Solution() : res(new ListNode(-1)){}
    ~Solution(){
        delete res;
    }
    ListNode *res;
    ListNode* reverseKGroup(ListNode* head, int k) {
        ListNode *p, *q, *l; //p为每次分段的头结点 l记录每段的头结点 为下一段的头结点
        q = head; //q为临时节点
        int len = 0; //链表的长度
        p = res;
        if(!head)
            return NULL;
        while(q) {
            len++;
            q = q->next;
        }
        int cnt = len / k;  //旋转段数
        q = head;
        if(cnt <= 0 && head) //不足反转次数 直接返回
            return head;
        while(cnt > 0) {
            int i = k;
            while(head && i> 0) {
                if(k == i) { //记住第一个元素位置 为下一段的头结点
                    l = q;
                }
                q = head->next;
                head->next = p->next;
                p->next = head;
                head = q;
                i--;
            }
            p = l;
            cnt--;
        }
        if(head) {
            l->next = head;
        }
        return res->next;
    }
全部评论

相关推荐

投递海康威视等公司10个岗位
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务