题解 | #链表中的节点每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;
    }
全部评论

相关推荐

沉淀一会:**圣经 1.同学你面试评价不错,概率很大,请耐心等待;2.你的排名比较靠前,不要担心,耐心等待;3.问题不大,正在审批,不要着急签其他公司,等等我们!4.预计9月中下旬,安心过节;5.下周会有结果,请耐心等待下;6.可能国庆节前后,一有结果我马上通知你;7.预计10月中旬,再坚持一下;8.正在走流程,就这两天了;9.同学,结果我也不知道,你如果查到了也告诉我一声;10.同学你出线不明朗,建议签其他公司保底!11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
双非坐过牢:非佬,可以啊10.28笔试,11.06评估11.11,11.12两面,11.19oc➕offer
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务