博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode]Reverse Linked List
阅读量:2236 次
发布时间:2019-05-09

本文共 1484 字,大约阅读时间需要 4 分钟。

解题思路:
A linked list can be reversed either iteratively or recursively. Could you implement both?
方法一,迭代法:
边界条件:head == NULL
前条件:temphead = head, p = tail, q = tail->next
不变式:head = head->next, 把temphead插入p和q之间

结束条件:head == p

/** * Definition for singly-linked list. * struct ListNode { *     int val; *     ListNode *next; *     ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {public:    ListNode* reverseList(ListNode* head) {        if (head == NULL)            return NULL;        ListNode *p = head;        while (p->next != NULL)            p = p->next;        ListNode *q = p->next;        ListNode *tempHead = head;        while(head != p){            tempHead = head;            head = head->next;            tempHead->next = q;            p->next = tempHead;            q = p->next;        }        return head;    }};
方法二,回溯法:
边界条件:head为NULL
前条件:找到尾节点
结束条件:head为NULL
不变式:寻找尾节点

/** * Definition for singly-linked list. * struct ListNode { *     int val; *     ListNode *next; *     ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {public:    ListNode* reverseList(ListNode* head) {        if (head == NULL)            return NULL;        if (head->next == NULL)            return head;        ListNode *p = head;        ListNode *q = p->next;        while(q->next != NULL){            p = q;            q = q->next;        }        ListNode *newHead = q;        p->next = q->next;        q->next = reverseList(head);        return newHead;    }};

转载地址:http://fjpbb.baihongyu.com/

你可能感兴趣的文章
java面试中常考的一些面试sql语句
查看>>
一个字节等于多少位?
查看>>
帧框架frameset的用法总结
查看>>
java1.8中创建hashmap的初始化大小设置标准
查看>>
mark一下,service的实现层没有加@service注解。
查看>>
jq对象转换成js对象。已经jq的复合选择器。
查看>>
(一)alin‘s mysql学习笔记----概述
查看>>
(二)alin’s mysql学习笔记----mysql的存储引擎
查看>>
(三)alin’s mysql学习笔记----常用的join连接查询
查看>>
(四)alin’s mysql学习笔记----索引简介
查看>>
分布式系统中的幂等性的理解
查看>>
spring的注解开发中的常用注解(一)------@bean @Configuration @ComponentScan @Import @Scope @Lazy
查看>>
(五)alin’s mysql学习笔记----索引性能分析
查看>>
Spring中使用@Transactional注解进行事务管理的时候只有应用到 public 方法才有效
查看>>
springboot整合rabbitmq及rabbitmq的简单入门
查看>>
mysql事务和隔离级别笔记
查看>>
事务的传播属性(有坑点)自调用失效学习笔记
查看>>
REDIS缓存穿透,缓存击穿,缓存雪崩原因+解决方案
查看>>
动态代理实现AOP
查看>>
23种常见的java设计模式
查看>>