剑指offer读书笔记一

一、 旋转数组(数组开始有序),寻找最小数。(比如0,1,2,3,4,5,6可以旋转为4,5,6,0,1,2,3等)。

旋转数组特性:

  1. 部分有序,即变成两个局部有序(但又特例)。
  2. 前面的有序子数组中的数总是大于等于后面有序子数组中的数(也有特例)。
  3. 特例是当旋转为0或者刚好为数组长度的整数倍时,数组变回最开始的数组,即有序而非局部有序,还有一个特例是大部分元素都相等。

突破点:

  1. 因为是有序的(尽管是局部有序),我们还是可以利用这个有序的特性通过二分查找来解决问题。
  2. 传统的二分查找是通过两个下标指针来指示我们要查找元素的的范围,并且不停折半缩小范围,缩小范围的同时让我们所查找的元素位置夹在两个下标之间;而这题也是类似,只是缩小范围的时候,判断方法有所不同弄,即上面的特性2,中间元素如果大于等于前面元素,则说明最小值在中间元素和以后,如果中间元素小于等于后面的元素,则说明最小值在中间值以前(包括中间值)。
  3. 特例处理,如果旋转为数组的整数倍长度时直接返回第0个袁术,如果大部分元素都相等时,使得中间值a[left]和a[right]以及a[mid]均相等,则采用顺序查找。

二、 斐波那契数列

常见题目:

  1. 写一个函数,输入n,求斐波那契数列的第n项。

     f(0) = 0; f(1) = 1; f(n) = f(n-1) + f(n-2);
    
  2. 一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求改青蛙跳上一个n级台阶总共有多少种跳法。

  3. 我们可以用2 X 1 的小矩形横着或者竖着去覆盖更大的矩形。请问8个2 X 1的小矩形无重复的覆盖一个2 X 8 的大矩形,总共有多少种方法?

这些题目都很类似,数列的第n项我们把它当做第n种状态,改变当前状态的方式(改变后为不同于当前状态的两种不同状态)通常有两种。所以当前状态是由前面两种不同状态的结果的和。

三、 位运算

一个整数n(大于0)减去1,在二进制的表示中的特点,因为二进制的表示中,一个位不是0就是1,如果是1,则减1后变为0,运算就此结束,而如果该位是0,则该位向前借1即该位变为2再减去1变为1,因为高位被借1其实也就相当于减1,在该位的运算与前面类似,直到遇到1,运算才结束。
仔细看运算过程发现,有如下特点:

  1. 运算会在遇到最右边的第一个1结束。
  2. 运算使得包括最右边第一个1右边的所有位都变得和原来相反,结合第1特性,运算后的二进制表示变为xxxx01111(原来为xxxx10000)。
  3. 如果与原来的整数做与位运算,则获得效果是将最右边的1变为0.

四、 快速幂的理解

求x的n次方

快速幂的思路就是把n分解为若干2的幂之和,然后从低次幂开始求,由于高次幂可以直接由低次幂求得,因此可以非常高效得求得。

例如求 x 的 10次幂,10可以分解为8 + 2(二进制表示为1000,10)
x的10次幂等于x的8次幂乘以x的2次幂,x的2次幂等于x * x, x的8次幂则等于4个x的2次幂相乘。

double pow(double base, int n)
{
    double res = 0.0;
    if(n == 0)
        return 1;
    while(n & 1 == 0){
        base *= base;
        n >= 1;
    }
    res = base;
    n >= 1;
    while(n){
        base *= base;
        if(n & 1)
            res *= base; 
        n >= 1;
    }
    return res;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,425评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,058评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,186评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,848评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,249评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,554评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,830评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,536评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,239评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,505评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,004评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,346评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,999评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,060评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,821评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,574评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,480评论 2 267

推荐阅读更多精彩内容

  • 前言 把《C++ Primer》[https://book.douban.com/subject/25708312...
    尤汐Yogy阅读 9,446评论 1 51
  • 指针是C语言中广泛使用的一种数据类型。 运用指针编程是C语言最主要的风格之一。利用指针变量可以表示各种数据结构; ...
    朱森阅读 3,387评论 3 44
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,293评论 18 399
  • 标签:ios开发入门 1` isKindOfClass用于判断某个对象是否为指定类,或者指定类的父类的对象 2` ...
    哇次哟累阅读 1,598评论 0 0
  • 世界上有一座神奇的纪念碑,碑文上镌刻的是那一串串脚印。记载着惊世的远征、艰难的跋涉。也记载着凄楚的彷徨、短暂的哀叹...
    逍遥女郎阅读 346评论 1 1