劍指offer 3

本期題目概覽

本期的五道題涉及到的知識點有:遞歸,整數的二進制表示,邏輯運算符,python中List 常用的內置方法。

chapter3

試題 11:變態跳臺階

一隻青蛙一次可以跳上1級臺階,也可以跳上2級……它也可以跳上n級。求該青蛙跳上一個n級的臺階總共有多少種跳法。

(遞歸想明白不容易,即使遞歸兩次認真去想那也很燒腦。之前看過一本書,作者對於遞歸給的建議:別想太多,相信信念。還別說,這樣一想就好用多了,而且還很少出錯。)

試題 12:矩陣覆蓋

我們可以用21的小矩形橫着或者豎着去覆蓋更大的矩形。請問用n個21的小矩形無重疊地覆蓋一個2*n的大矩形,總共有多少種方法?

試題 13:二進制中1的個數

輸入一個整數,輸出該數二進制表示中1的個數。其中負數用補碼錶示。

試題 14:數值的整數次方

給定一個double類型的浮點數base和int類型的整數exponent。求base的exponent次方。保證base和exponent不同時爲0

試題 15:調整數組順序使奇數位於偶數前面

輸入一個整數數組,實現一個函數來調整該數組中數字的順序,使得所有的奇數位於數組的前半部分,所有的偶數位於數組的後半部分,並保證奇數和奇數,偶數和偶數之間的相對位置不變。

相關代碼

試題 11:變態跳臺階

# 解題思路:參考牛客網(https://www.nowcoder.com/profile/6927081)

# 關於本題,前提是n個臺階會有一次n階的跳法。分析如下:
# f(1) = 1
#
# f(2) = f(2 - 1)   f(2 - 2) // f(2 - 2)
# 表示2階一次跳2階的次數。
#
# f(3) = f(3 - 1)   f(3 - 2)   f(3 - 3)
#
# ...
#
# f(n) = f(n - 1)   f(n - 2)   f(n - 3)   ...   f(n - (n - 1))   f(n - n)
#
# 說明:
#
# 1)這裏的f(n)代表的是n個臺階有一次1, 2, ...n階的跳法數。
#
# 2)n = 1時,只有1種跳法,f(1) = 1
#
# 3) n = 2時,會有兩個跳得方式,一次1階或者2階,這回歸到了問題(1) ,f(2) = f(2 - 1)   f(2 - 2)
#
# 4) n = 3時,會有三種跳得方式,1階、2階、3階,
#
# 那麼就是第一次跳出1階後面剩下:f(3 - 1);
# 第一次跳出2階,剩下f(3 - 2);第一次3階,那麼剩下f(3 - 3)
#
# 因此結論是f(3) = f(3 - 1)   f(3 - 2)   f(3 - 3)
#
# 5) n = n時,會有n中跳的方式,1階、2階...n階,得出結論:
# f(n) = f(n - 1)   f(n - 2)   ...   f(n - (n - 1))   f(n - n) = > f(0)   f(1)   f(2)   f(3)   ...   f(n - 1)
#
# 6) 由以上已經是一種結論,但是爲了簡單,我們可以繼續簡化:
#
# f(n - 1) = f(0)   f(1)   f(2)   f(3)   ...   f((n - 1) - 1) = f(0)   f(1)   f(2)   f(3)   ...   f(n - 2)
#
# f(n) = f(0)   f(1)   f(2)   f(3)   ...   f(n - 2)   f(n - 1) = f(n - 1)   f(n - 1)
# 可以得出:
# f(n) = 2 * f(n - 1)
#
# 7) 得出最終結論, 在n階臺階,一次有1、2、...n階的跳的方式時,總得跳法爲:
#
#             | 1       ,(n=0 )
# f(n) =      | 1       ,(n=1 )
#             | 2*f(n-1),(n>=2)
# -*- coding:utf-8 -*-
class Solution:
    def jumpFloorII(self, number):
        # write code here
        if number < 1:
            return number
        else:
            return pow(2, number - 1)

試題 12:矩陣覆蓋

# 解題思路:
# 還是斐波那契數列
# number <= 2 時,直接返回結果
# number > 2 時,f(n) = f(n-1)   f(n-2)
# -*- coding:utf-8 -*-
class Solution:
    def rectCover(self, number):
        # write code here
        if number <= 2:
            return number
        else:
            item1, item2, ans = 1, 2, 0
            for i in range(2, number):
                ans = item1   item2
                item1, item2 = item2, ans
            return ans

試題 13:二進制中1的個數

# 方法 1
# 藉助邏輯運算符
def NumberOf2(n):
        # write code here
        count = 0
        flag = 1
        for _ in range(32):
            if flag & n != 0:
                count  = 1
            flag <<= 1
        return count
# 方法2
def numberOf(n):
    return sum([(n>>i & 1) for i in range(32)])

試題 14:數值的整數次方

# 方法 1
def Power(base, exponent):
    return pow(base,exponent)

# 方法 2
# -*- coding:utf-8 -*-
class Solution:
    def Power(self, base, exponent):
        # write code here
        result = 1
        if exponent == 0:
            return 1
        elif exponent > 0:
            for i in range(exponent):
                result *= base
            return result
        else:
            for i in range((-1)*exponent):
                result *= base
            return 1.0/result

試題 15:調整數組順序使奇數位於偶數前面

# -*- coding:utf-8 -*-
# 思路:
# 藉助List insert(),挨個判斷所給數組array中的元素,
# 索引index記錄要插入數據的位置(從第一個位置開始),
# 當奇數元素放置好後,偶數元素對應地也會放置好。
class Solution:
    def reOrderArray(self, array):
        # write code here
        index = -1
        for i in range(len(array)):
            if array[i] & 1 != 0:
                index  = 1
                array.insert(index, array.pop(i))
        return array

餘下的以及之前的題目將會陸續放到github,點擊閱讀原文查看。

本文由博客一文多發平臺 OpenWrite 發佈!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章