leetcode509. 斐波那契數(矩陣快速冪)

斐波那契數,通常用?F(n) 表示,形成的序列稱為斐波那契數列。該數列由?0 和 1 開始,后面的每一項數字都是前面兩項數字的和。也就是:

F(0) = 0,???F(1)?= 1
F(N) = F(N - 1) + F(N - 2), 其中 N > 1.
給定?N,計算?F(N)。

示例 1:

輸入:2
輸出:1
解釋:F(2) = F(1) + F(0) = 1 + 0 = 1.
示例 2:

輸入:3
輸出:2
解釋:F(3) = F(2) + F(1) = 1 + 1 = 2.
示例 3:

輸入:4
輸出:3
解釋:F(4) = F(3) + F(2) = 2 + 1 = 3.

矩陣快速冪

class Solution {int fib(int N) {if (N <= 1) {return N;}int[][] A = new int[][]{{1, 1}, {1, 0}};matrixPower(A, N-1);return A[0][0];}void matrixPower(int[][] A, int N) {if (N <= 1) {return;}matrixPower(A, N/2);multiply(A, A);int[][] B = new int[][]{{1, 1}, {1, 0}};if (N%2 != 0) {multiply(A, B);}}void multiply(int[][] A, int[][] B) {int x = A[0][0] * B[0][0] + A[0][1] * B[1][0];int y = A[0][0] * B[0][1] + A[0][1] * B[1][1];int z = A[1][0] * B[0][0] + A[1][1] * B[1][0];int w = A[1][0] * B[0][1] + A[1][1] * B[1][1];A[0][0] = x;A[0][1] = y;A[1][0] = z;A[1][1] = w;}
}

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/444105.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/444105.shtml
英文地址,請注明出處:http://en.pswp.cn/news/444105.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

insert函數的修改,

我們來看一下圖片當中的第2個圓圈&#xff0c;為什么使用size來相加呢&#xff1f;我們知道一開始我們定義的初始空間為init_size;我們想一下啊&#xff0c;如果是第1次進行空間的增加&#xff0c;那么我們使用InIt來進行相加是可以的&#xff0c;但是當第2次想加我們再想開辟空…

leetcode520. py解字符串真是太殘暴了

給定一個單詞&#xff0c;你需要判斷單詞的大寫使用是否正確。 我們定義&#xff0c;在以下情況時&#xff0c;單詞的大寫用法是正確的&#xff1a; 全部字母都是大寫&#xff0c;比如"USA"。 單詞中所有字母都不是大寫&#xff0c;比如"leetcode"。 如果…

【數據結構】線性表大咖

循環鏈表的介紹 概念&#xff1a;鏈表的最后一個節點的指針&#xff0c;由原來的 空指針變成指向第1個節點的鏈表。 類比&#xff1a;我們進行串珠子的操作&#xff0c;將首尾通過線進行連接&#xff0c;同樣我們的鏈表就是通過指針指向的方式進行連接&#xff0c;使其成為一…

leetcode551. 學生出勤記錄 I

給定一個字符串來代表一個學生的出勤記錄&#xff0c;這個記錄僅包含以下三個字符&#xff1a; A : Absent&#xff0c;缺勤 L : Late&#xff0c;遲到 P : Present&#xff0c;到場 如果一個學生的出勤記錄中不超過一個A(缺勤)并且不超過兩個連續的L(遲到),那么這個學生會被獎…

一元多項式的表示和相加【數據結構】

一元多項式的表示和相加 運算只是一個定義&#xff0c;一切的一切&#xff0c;到最后都必須歸咎于存儲結構當中&#xff0c;實現物理存儲&#xff0c;一元多項式包括數據對象數據關系以及數據之間的各種操作&#xff0c; 一元多項式的實現&#xff1a;用帶表頭結點的有序鏈表…

線性結構基本概念【數據結構】F

線性表的概念&#xff1a;線性表是一種最簡單的線性結構&#xff0c;線性結構是單個數據元素的有序結合 線性結構的基本特征為&#xff1a; 第一&#xff0c;集合中必存在唯一的一個第1元素&#xff0c; 第二&#xff0c;集合中必存在唯一的一個最后元素&#xff0c; 第三&am…

leetcode589. N叉樹的前序遍歷

給定一個 N 叉樹&#xff0c;返回其節點值的前序遍歷。 例如&#xff0c;給定一個 3叉樹 : 返回其前序遍歷: [1,3,5,6,2,4]。 思路&#xff1a;先放入自己&#xff0c;再依次遍歷孩子。 /* // Definition for a Node. class Node {public int val;public List<Node> c…

ORA-00001 違反唯一約束條件

程序跑出下面的異常&#xff1a;com.ibm.websphere.ce.cm.DuplicateKeyException: ORA-00001: 違反唯一約束條件 (EOMS3.SYS_C0024492)&#xff0c;參考下面的文章了解到我的程序可能是序列的問題。&#xff08;果然是序列產生的最小值設置的太小&#xff0c;將序列值設置大之后…

順序結構實現【數據結構】

雖然在數據結構當中是先出現的線性表&#xff0c;然后出現的是數組 一&#xff1a;線性表的順序存儲結構 順序映象&#xff1a;用一組地址連續的存儲單元依次存放線性表當中的數據元素 線性表的起始地址&#xff1a;線性存儲第一個數據元素的地址&#xff0c;我們也稱作是基地址…

leetcode590. N叉樹的后序遍歷

給定一個 N 叉樹&#xff0c;返回其節點值的后序遍歷。 例如&#xff0c;給定一個 3叉樹 : 思路&#xff1a;先遍歷所有孩子&#xff0c;再放入自己。 /* // Definition for a Node. class Node {public int val;public List<Node> children;public Node() {}public No…

鏈表的形式【F】

數據元素之間的關系在計算機中有兩種表示方法: 順序映象, 非順序映象. 對應兩種存儲結構: 順序存儲結構, 鏈式存儲結構 線性結構就是一種邏輯關系&#xff0c;方便我們對數據進行研究但是不考慮真實的存儲結構 數據是什么&#xff1f; 數據是能夠反應一定內容的一組數據類型的…

leetcode892. 三維形體的表面積

在 N * N 的網格上&#xff0c;我們放置一些 1 * 1 * 1 的立方體。 每個值 v grid[i][j] 表示 v 個正方體疊放在對應單元格 (i, j) 上。 請你返回最終形體的表面積。 示例 1&#xff1a; 輸入&#xff1a;[[2]] 輸出&#xff1a;10 示例 2&#xff1a; 輸入&#xff1a;…

leetcode914. 卡牌分組

給定一副牌&#xff0c;每張牌上都寫著一個整數。 此時&#xff0c;你需要選定一個數字 X&#xff0c;使我們可以將整副牌按下述規則分成 1 組或更多組&#xff1a; 每組都有 X 張牌。 組內所有的牌上都寫著相同的整數。 僅當你可選的 X > 2 時返回 true。 示例 1&#xf…

單鏈表的實現【數據結構】

思考&#xff1a; 1.是否能夠將原來指針的方向改為向前指向呢&#xff1f; 2.是否能夠有兩個指針域的操作呢&#xff1f; 了解&#xff1a; 單鏈表是應用最廣泛的一種形式&#xff0c;還有雙向鏈表以及循環鏈表&#xff0c;這些都是要進行討論的 結構體定義的是什么&#xff1f…

(詳細圖解)VS2017安裝教程

VS 2017 版本同 15 版一樣&#xff0c;細分為三個版本&#xff0c;分別是&#xff1a; 社區版&#xff08;Community&#xff09;&#xff1a;免費提供給單個開發人員&#xff0c;給予初學者及大部分程序員支持&#xff0c;可以無任何經濟負擔、合法地使用。企業版&#xff1a…

鏈表的代碼實現【數據結構F】

單鏈表的特點&#xff1a;每次結點的分配都是動態進行分配的&#xff0c;melloc函數實現的功能是開辟一塊新的內存空間&#xff0c;但是返回的是一個地址&#xff0c;只能是地址&#xff0c;沒有別名的事情&#xff0c;那就有點難辦了&#xff0c;這是一種間接的尋址&#xff0…

(圖文詳細)如何使用Code::Blocks運行c/cpp文件?

1) 新建源文件 打開 CodeBlocks &#xff0c;在上方菜單欄中選擇 “文件 --> 新建 --> 空白文件”&#xff0c;如下圖所示&#xff1a; 或者直接按下 Ctrl Shift N 組合鍵&#xff0c;都會新建一個空白的源文件&#xff0c;如下圖所示&#xff1a; 在空白源文件中輸入…

數據結構【插入操作具體代碼的實現】

插入操作具體代碼的實現 單鏈表delete的操作&#xff1a;

Linux GCC簡明教程(編寫c語言程序)

市面上常見的 Linux 都是發行版本&#xff0c;典型的 Linux 發行版包含了 Linux 內核、桌面環境&#xff08;例如 GNOME、KDE、Unity 等&#xff09;和各種常用的必備工具&#xff08;例如 Shell、gcc、VIM、Firefox 等&#xff09;&#xff0c;國內使用較多的是 CentOS、Ubunt…

Oracle中如何獲取當天時間的最開始的時間和最結尾的時間:

如下&#xff1a; 1.獲取當前時間的最開始的時間&#xff1a; select to_char(TRUNC(SYSDATE),yyyy-mm-dd hh24:mi:ss) from dual; 結果&#xff1a;2013-08-26 00:00:00 2.獲取當前時間的最結尾的時間&#xff1a; selectTRUNC(SYSDATE)1-1/86400 FROM dual; 結果&#x…