摘要:
难度:naive做法60,计数排序 scan两次也是一种办法,第一次把1和2当做一种颜色,放到0的右边,第二次0已经全部在左边,只需把2放到1右边 我们考虑怎么用一次扫描来解决。 Best Solution(Discuss里vote最高): the basic idea is to use two 阅读全文
posted @ 2014-09-19 12:58
neverlandly
阅读(300)
评论(0)
推荐(0)
摘要:
Implement int sqrt(int x). 难度:76,用二分查找。要求是知道结果的范围,取定左界和右界,然后每次砍掉不满足条件的一半,知道左界和右界相遇。算法的时间复杂度是O(logx),空间复杂度是O(1)。 1 public class Solution { 2 public int 阅读全文
posted @ 2014-09-19 12:09
neverlandly
阅读(525)
评论(0)
推荐(0)
摘要:
难度:90. 这道题跟Palindrome Partitioning非常类似,区别就是不需要返回所有满足条件的结果,而只是返回最小的切割数量就可以。做过Word Break的朋友可能马上就会想到,其实两个问题非常类似,当我们要返回所有结果(Palindrome Partitioning和Word B 阅读全文
posted @ 2014-09-19 09:08
neverlandly
阅读(581)
评论(0)
推荐(0)
摘要:
Given a string s, partition s such that every substring of the partition is a palindrome.Return all possible palindrome partitioning of s.For example,... 阅读全文
posted @ 2014-09-19 07:33
neverlandly
阅读(594)
评论(0)
推荐(0)
摘要:
第二次做法:用API 第一次做法:难度:79. 这道题是判断一个字符串是不是回文串。因为只是看一个字符串,算法还是比较简单,就是从两头出发,往中间走,进行两两匹配。这里面的小问题就是在这个题目要求中,只判断字母和数字类型的字符,其他字符直接跳过即可。因此我们要写一个函数判断他是不是合法字符,而且因为 阅读全文
posted @ 2014-09-19 05:36
neverlandly
阅读(466)
评论(0)
推荐(0)
摘要:
Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center).For example, this binary tree is symmetric: 1 / \ ... 阅读全文
posted @ 2014-09-19 04:35
neverlandly
阅读(269)
评论(0)
推荐(0)
摘要:
需要保证的是左子树所有节点都小于根,而并非仅仅左子树根。所以Recursion里面要存的是可以取值的范围。其实就是对于每个结点保存左右界,也就是保证结点满足它的左子树的每个结点比当前结点值小,右子树的每个结点比当前结点值大。对于根节点不用定位界,所以是无穷小到无穷大,接下来当我们往左边走时,上界就变 阅读全文
posted @ 2014-09-19 03:29
neverlandly
阅读(825)
评论(1)
推荐(0)
摘要:
难度:89. 这道题是要求恢复一颗有两个元素调换错了的二叉查找树。一开始拿到可能会觉得比较复杂,其实观察出规律了就比较简单。主要还是利用二叉查找树的主要性质,就是中序遍历是有序的性质。那么如果其中有元素被调换了,意味着中序遍历中必然出现违背有序的情况。那么会出现几次呢?有两种情况,如果是中序遍历相邻 阅读全文
posted @ 2014-09-19 00:52
neverlandly
阅读(392)
评论(0)
推荐(0)
浙公网安备 33010602011771号