第一周leetcode

3/27 胡乱投了一堆简历,做了七牛的笔试,看了腾讯的面试题

感觉不懂的还是很多啊,不过也知道了笔试套路其实也不多,基本算法/数据结构(不会太难)、c/c++基础(后面的知识类似虚函数需要了解)、linux及多线程、网络和HTTP、数据库

这周本来想做完华为的精英赛题,感觉很有把握的,结果电脑联网报废了,linux环境也GG了,心情略差

开始做leetcode,挺慢的,希望以后进度提快


1.Two Sum

给一个vector<int> nums 和一个int k,求nums[i]+nums[j]=k时的return [i , j],需要注意是i,j和要最小, 知识点:vector.size()

292.Nim Game

找规律的题 隔4取一次 ,记住就行了

8.String to  Integer(atoi)

string转换为int,本身并不难,但是边界条件很多:1.允许开头*个空字符,允许开头有'-''+'2.不允许数字中出现除'0'-'9'以外的字符3.结果大于MAX小于MIN返回MAX个MIN

388.Counting Bits

给一个k,return从0到k每个值中二进制的1的个数

注意:1.计算二进制中1的个数,难点在于时间复杂度。有三种基本求二进制1个数的方法:

(1)定理求解:取余数的方法,最慢。

(2)基本法(雾):值和1进行&操作,然后>>算术右移,仍然有两个循环。(即为本道题我的解法)

(3)快速法:n和n-1进行&操作,可以消去二进制最右的1,仍然有两个循环。(在191题中的解法)

191.Number of 1 Bits

求一个uint32_t n二进制中1的个数,用快速法

136.Single Number

寻找序列内单个的数。

我的方法(线性时间复杂度,不利用其他空间):先sort一遍排列,和前后两个数都不相等的就是所求,序列长度为1为边界条件

快速方法:所有数按位异或即为结果(因为异或满足结合律)

知识点:vector.begin() vector.end()

104. Maximum Depth of Binary Tree

求二叉树深度,很久没做递归了,画了一下还是写出来了,但是有个结果submit一直报错,但是run code里没问题

原因:用C写的时候在函数外面设置了变量(实际上是全局变量),改为C++后设置为class中的private就好了

258. Add Digits

第一个看的leetcode题,初见O(1)吓到了我,原来是数学法则(高级找规律)return (num-1)%9 + 1;

226. Invert Binary Tree

翻转二叉树,我意识到对C++需要了解的不是奇技淫巧,而是踏实的重载、多态、继承、虚函数等,这样的题目反而简单

最后3道题做完了但是没copy代码到blog上。

 

posted @ 2016-03-27 12:14  Dystopia  阅读(143)  评论(0编辑  收藏  举报