Leetcode 234 Palindrome Linked List 复杂度为时间O(n) 和空间(1)解法
来源:互联网 发布:淘宝卖家为什么不发货 编辑:程序博客网 时间:2024/05/16 16:05
1. 问题描述
给定一个单链表,判断其内容是不是回文类型。例如1–>2–>3–>2–>1。时间和空间复杂都尽量低。
2. 方法与思路
1)比较朴素的算法。
由于给定的数据结构是单链表,要访问链表的尾部元素,必须从头开始遍历。为了方便判断,我们可以申请一个辅助栈结构来存储链表的内容,第一次遍历将链表节点值依次入栈,第二次遍历比较判断是否为回文。
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {public: bool isPalindrome(ListNode* head) { if(head == NULL || head->next == NULL) return true; stack<int> st; ListNode *tmp = head; while(tmp) { st.push(tmp->val); tmp = tmp->next; } while(head) { if(head->val != st.top() ) return false; head = head->next; st.pop(); } return true; }};
2). 时间O(n)和空间O(1)解法
既然用到了栈,可以想到递归的过程本身就是出入栈的过程,我们可以先递归访问单链表,然后做比较。这样就省去了辅助空间,从而将空间复杂度降为O(1)。代码如下:
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {private: ListNode *lst;public: bool judge(ListNode *head) { if(head == NULL) return true; if(judge(head->next) == false) return false; if(lst->val != head->val) return false; else{ lst = lst->next; return true; } } bool isPalindrome(ListNode* head) { if(head == NULL || head->next == NULL) return true; lst = head; return judge(head); }};
0 0
- Leetcode 234 Palindrome Linked List 复杂度为时间O(n) 和空间(1)解法
- 时间复杂度为O(n),空间复杂度为O(1)
- 青蛙跳台阶解法 时间复杂度O(n) 空间复杂度O(1)
- 字符串移动k位的时间复杂度o(n)空间复杂度o(1)的解法
- Leetcode 238 Product of Array Except Self 时间O(n)和空间O(1)解法
- 排序的时间复杂度为O(n),空间复杂度为O(1)
- 时间复杂度为O(N),空间复杂度为O(1)的排序算法
- leetCode & hihocoder:最长回文子字符串时间复杂度为O(N)解法
- leetCode & hihocoder:最长回文子字符串时间复杂度为O(N)解法
- 找出一个数组中出现次数超过一半的那个数字,要求时间复杂度O(n)和空间复杂度为O(1)。
- Candy [leetcode] O(n)时间复杂度,O(1)空间复杂度的方法
- Candy [leetcode] O(n)时间复杂度,O(1)空间复杂度的方法
- 数组中只出现一次的数字,时间复杂度O(n),空间复杂度O(1)的解法
- 时间复杂度O(n),空间复杂度O(1)的排序
- O(N)时间复杂度、O(1)空间复杂度 构造数组
- LeetCode 148. Sort List--O(nlogn)时间复杂度和常数空间复杂度给链表排序
- 不用额外空间的整数交换以及时间复杂度为O(n)空间复杂度为O(1)的排序算法
- LeetCode Reorder List O(n) space空间解法
- XMLHttpRequest对象
- 没钱买珍珠首饰,可以画一个
- java 关于日期
- Jquery多次绑定click事件
- linux系统下查看图片尺寸的命令
- Leetcode 234 Palindrome Linked List 复杂度为时间O(n) 和空间(1)解法
- OrmLite使用小结(一)
- SQL注入的一般步骤及防范方法
- linux动态链接相关
- SQL注入原理,值得一看
- remove-duplicates-from-sorted-array-ii
- TCP长连接与短连接的区别
- android 轮播图手动循环滑动+自动循环滑动
- ios修改NavigationController的背景颜色