劍指Offer10-I.斐波那契數列 C++

1、題目描述

寫一個函數,輸入 n ,求斐波那契(Fibonacci)數列的第 n 項(即 F(N))。斐波那契數列的定義如下:
F(0) = 0, F(1) = 1
F(N) = F(N - 1) + F(N - 2), 其中 N > 1.
斐波那契數列由 0 和 1 開始,之后的斐波那契數就是由之前的兩數相加而得出。
答案需要取模 1e9+7(1000000007),如計算初始結果為:1000000008,請返回 1。
示例 1
輸入:n = 2
輸出:1
示例 2:
輸入:n = 5
輸出:5

2、VS2019上運行

代碼隨想錄的五步曲

#include <iostream>
#include <vector>class Solution {
public:int fib(int N) {if (N <= 1) return N;std::vector<int> dp(N + 1); // 創建一個長度為 N+1 的動態數組 dpdp[0] = 0;dp[1] = 1;for (int i = 2; i <= N; i++) {dp[i] = dp[i - 1] + dp[i - 2]; // 計算斐波那契數列第 i 項的值}return dp[N]; // 返回斐波那契數列第 N 項的值}
};int main() {int N = 5;Solution s;int result = s.fib(N); // 調用 fib 方法計算斐波那契數列第 N 項的值std::cout << "Fibonacci number at position " << N << " is: " << result << std::endl;return 0;
}

運行結果:
Fibonacci number at position 5 is: 5
(這里出問題了,N=45時就出現錯誤,這是因為對于斐波那契數列,隨著 n 的增加,數列的值增長非常迅速。當使用普通的整數類型(如 int 或 long long)進行計算時,這些類型的取值范圍是有限的,無法容納較大的斐波那契數列項。)

換官方題解

#include <iostream>class Solution {
public:int fib(int n) {int MOD = 1000000007;  // 定義一個常量 MOD,用于取模運算if (n < 2) {return n;  // 如果 n 小于 2,直接返回 n 的值,因為斐波那契數列的前兩項是 0 和 1}int p = 0, q = 0, r = 1;  // 初始化前兩項和當前項的值for (int i = 2; i <= n; ++i) {p = q;  // 將 q 的值賦給 p,保留前一個項的值q = r;  // 將 r 的值賦給 q,更新當前項的值r = (p + q) % MOD;  // 計算下一項的值,并對 MOD 取模以避免溢出}return r;  // 返回斐波那契數列第 n 項的值}
};int main() {int N = 10;Solution s;  // 創建 Solution 類的對象int result = s.fib(N);  // 調用 fib 方法計算斐波那契數列第 N 項的值std::cout << "Fibonacci number at position " << N << " is: " << result << std::endl;return 0;
}

運行結果:
Fibonacci number at position 10 is: 55

3、代碼隨想錄解題思路

代碼隨想錄的動態規劃五步曲

  • 1、確定dp數組(dp table)以及下標的含義
  • 2、確定遞推公式
  • 3、dp數組如何初始化
  • 4、確定遍歷順序
  • 5、舉例推導dp數組

4、官方題解解題思路

  • 1.首先,我們定義了一個類 Solution,其中包含一個名為 fib 的方法,用于計算斐波那契數列的第 N 項的值。
  • 2.在 fib 方法中,我們首先定義了一個常量 MOD,用于進行取模運算。這個常量的值是 1000000007,是為了在計算過程中避免溢出。
  • 3.接下來,我們使用一個條件語句判斷給定的 n 是否小于 2。如果是,則直接返回 n 的值,因為斐波那契數列的前兩項是 0 和 1,所以它們的值與 n 相等。
  • 4.然后,我們初始化三個變量 p、q 和 r 分別為 0、0 和 1。這些變量分別表示當前項、前一項和下一項的值。
  • 5.進入循環,從索引 2 開始,直到 n。在每次循環中,我們更新變量的值:將 q 的值賦給 p,r 的值賦給 q,并計算 (p + q) % MOD 的結果并賦給 r。這樣就實現了逐步計算斐波那契數列的下一項的值。
  • 6.循環結束后,我們返回變量 r 的值作為斐波那契數列的第 N 項的結果。

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

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

相關文章

Redis_事務操作

13. redis事務操作 13.1事務簡介 原子性(Atomicity) 一致性(Consistency) 隔離性(isolation) 持久性(durabiliby) ACID 13.2 Redis事務 提供了multi、exec命令來完成 第一步&#xff0c;客戶端使用multi命令顯式地開啟事務第二步&#xff0c;客戶端把事務中要執行的指令發…

前沿分享-通過經皮神經刺激來治療糖尿病神經性疼痛

經皮神經電刺激&#xff08;PENS&#xff09;設備用于對糖尿病周圍神經病變引起的慢性、頑固性疼痛進行多次治療。 放在耳朵上的這種可穿戴設備在幾天內持續提供低水平的脈沖電流。 這是一種安全有效的非麻醉性替代治療慢性疼痛的方法。還有一張設備放在糖足上的照片&#xff0…

向量數據庫 Milvus Cloud Partition Key:租戶數量多,單個租戶數據少的三種解決方案

三種解決方案 這個問題提出的時候,Milvus 的最新版本是 2.2.8,我們做個角色互換,在當時站在這個用戶的角度,留在我們面前的選擇有這么幾個: 為每個租戶創建一個 collection 為每個租戶創建一個 partition 創建一個租戶名稱的標量字段 接下來,我們依次分析下這三種方案的可…

《零基礎實踐深度學習》(第2版)學習筆記,(五)深度學習與計算機視覺

文章目錄 1. 計算機視覺概述2. 圖像分類3. 目標檢測 1. 計算機視覺概述 圖像分類 目標檢測 2. 圖像分類 3. 目標檢測

01-C++數據類型

3、基礎類型 3.1、簡單變量 變量的命名 carDrip和cardRip 或boat_sport和boats_port 此外&#xff0c;還有有前綴的命名&#xff0c;使用前綴表示數據類型。常見的前綴有:str&#xff08;表示字符串&#xff09;、n&#xff08;表示整數值&#xff09;、b&#xff08;表示…

深入探究QCheckBox的三種狀態及其用法

文章目錄 引言&#xff1a;三種狀態一、未選中狀態&#xff08;0&#xff09;&#xff1a;二、選中狀態&#xff08;2&#xff09;&#xff1a;三、部分選中狀態&#xff08;1&#xff09;&#xff1a; 判斷方法結論&#xff1a; 引言&#xff1a; QCheckBox是Qt框架中常用的復…

html css實現愛心

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><style>/* 愛心 */.lo…

修改Linux中SSH的端口

文章目錄 修改Linux中SSH的端口Linux中默認的ssh端口關閉SELinux測試新端口 修改Linux中SSH的端口 Linux中默認的ssh端口 使用root用戶操作 修改前先備份ssh_config cp /etc/ssh/sshd_config /etc/ssh/sshd_config_date "%Y%m%d%H%M%S"修改配置文件&#xff0c;找…

結構體的定義與賦值

1、結構體定義 首先定義一個學生結構體&#xff0c;如下所示&#xff1a; struct Student {int num;char name[32];char sex;int age; }; 接著在主函數中對學生進行聲明&#xff0c;如下所示&#xff1a; #include<iostream> using namespace std;struct Student {in…

2023Robocom省賽(本科組)

RC-u1 亞運獎牌榜 題目鏈接&#xff1a;PTA | 程序設計類實驗輔助教學平臺 (pintia.cn) 題目&#xff1a; 2022 年第 19 屆亞運會即將在杭州召開&#xff0c;杭州已經做好準備歡迎全亞洲的觀眾一同參與亞運盛會了&#xff01; 你正在開發一款跟亞運獎牌計算相關的 App。給定…

“深入探究JVM內部結構與工作原理:解析Java虛擬機“

標題&#xff1a;深入探究JVM內部結構與工作原理 摘要&#xff1a;本文將深入探究Java虛擬機&#xff08;JVM&#xff09;的內部結構與工作原理。我們將介紹JVM的基本組成部分&#xff0c;包括類加載器、運行時數據區和執行引擎。同時&#xff0c;我們將通過一個示例代碼來說明…

直接在html中引入Vue.js的cdn來實現一個簡單的上傳圖片組件

摘要 當使用 Vue.js 的 CDN 來實現一個簡單的上傳圖片組件時&#xff0c;你可以利用 Vue 的數據綁定和事件處理能力&#xff0c;結合 HTML 和 CSS&#xff0c;輕松地創建一個交互式的圖片上傳界面。以下是一個示例&#xff1a; 代碼結構 index.html <!DOCTYPE html> &…

LVS集群和分布式

LVS 一.集群和分布式概念 1.1 集群 在計算機領域&#xff0c;集群早在 1960 年就出現&#xff0c;隨著互聯網和計算機相關技術的發展&#xff0c;現在 集群這一技術已經在各大互聯網公司普及。 1.1.1 集群概念 計算機集群指一組通過計算機網絡連接的計算機&#xff0c;它們…

Rust 重載運算符|復數結構的“加減乘除”四則運算

復數 基本概念 復數定義 由實數部分和虛數部分所組成的數&#xff0c;形如a&#xff0b;bi 。 其中a、b為實數&#xff0c;i 為“虛數單位”&#xff0c;i -1&#xff0c;即虛數單位的平方等于-1。 a、b分別叫做復數a&#xff0b;bi的實部和虛部。 當b0時&#xff0c;a&…

前后端分離------后端創建筆記(06)新增接口頁面布局

本文章轉載于【SpringBootVue】全網最簡單但實用的前后端分離項目實戰筆記 - 前端_大菜007的博客-CSDN博客 僅用于學習和討論&#xff0c;如有侵權請聯系 源碼&#xff1a;https://gitee.com/green_vegetables/x-admin-project.git 素材&#xff1a;https://pan.baidu.com/s/…

Kubernetes入門 四、Pod核心

目錄 什么是PodPod與容器不同Pod如何管理多個容器Pod的管理-工作負載K8s中的資源清單創建使用Pod直接創建Pod使用 Deployment 創建Pod 環境變量重啟策略鏡像拉取策略訪問 DNS 的策略資源限制初始化容器臨時容器&#xff08;了解&#xff09; 什么是Pod Pod 是可以在 Kubernete…

Azure添加網絡接口

添加網絡接口的意義 在 Azure 上&#xff0c;為虛擬機添加網絡接口的意義包括以下幾個方面&#xff1a; 擴展網絡帶寬&#xff1a;通過添加多個網絡接口&#xff0c;可以增加虛擬機的網絡帶寬&#xff0c;提高網絡傳輸速度和數據吞吐量。實現網絡隔離&#xff1a;每個網絡接口…

zabbix-6.4 監控 MySQL

目錄 1、rpm安裝zabbix_agentd服務 2、編寫zabbix_agentd.conf文件 3、編寫模板文件 4、創建mysql用戶并賦權限 5、創建.my.cnf文件 6、將規則添加到SELinux策略中 注意&#xff1a; 若模板無法讀取.my.cnf 信息&#xff0c;從而導致監控報錯&#xff0c;可以嘗試修改模…

虛樹

虛樹是用來優化樹形dp的東西&#xff0c;它的轉移是從一些特殊點&#xff0c;向根節點轉移&#xff0c;期間它有用的轉移點比較特殊。通常詢問次數較多&#xff0c;但特殊點總和較少&#xff0c;就可以每次詢問先建虛樹再跑dp。單調棧建虛樹 O ( k l o g n ) O(klogn) O(klogn)…

別人直播的時候怎么錄屏?分享一些錄屏方法

?隨著互聯網的快速發展&#xff0c;直播已經成為人們日常生活中不可或缺的一部分。但是&#xff0c;有時候我們可能會錯過某些重要的直播內容&#xff0c;這時候就需要錄屏來保存和觀看。那么&#xff0c;如何錄屏別人的直播呢&#xff1f;本文將分享一些錄屏方法和技巧&#…