亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MATLAB算法技巧和實(shí)現(xiàn)斐波那契數(shù)列的解決思路

 更新時(shí)間:2022年12月16日 11:18:03   作者:KANLON  
這篇文章主要介紹了MATLAB算法技巧和實(shí)現(xiàn)斐波那契數(shù)列,這篇主要說(shuō)一下自己在算法設(shè)計(jì)課上用matlab做的兩道算法題,題目解起來(lái)都比較簡(jiǎn)單,但是需要些技巧,需要的朋友可以參考下

MATLAB算法技巧和實(shí)現(xiàn)斐波那契數(shù)列

這篇博客主要說(shuō)一下自己在算法設(shè)計(jì)課上用matlab做的兩道算法題,題目解起來(lái)都比較簡(jiǎn)單,但是需要些技巧。

  • 公倍數(shù)的應(yīng)用
  • 斐波那契數(shù)列的應(yīng)用

題目要求

題目一:公倍數(shù)的應(yīng)用

  心里想好一個(gè)1~100之間的整數(shù)x,將它分別除以3,5,7并得到3個(gè)余數(shù)。把這三個(gè)余數(shù)輸入計(jì)算機(jī),計(jì)算機(jī)能馬上猜出這個(gè)數(shù)

題目二:斐波那契數(shù)列的應(yīng)用

  斐波那契數(shù)列有如下特點(diǎn):a1,a2已知 a(n)=a(n-1)+a(n-2) n>=3
  例題:樓梯上有n階臺(tái)階,上樓時(shí)可以一步上1階,也可以一步上2階,編寫(xiě)算法計(jì)算共有多少種不同的上樓梯方法

解題思路

問(wèn)題一,問(wèn)題一可以將該數(shù)轉(zhuǎn)換為d=70*a+21*b+15*c的乘積,主要是利用了他們的公倍數(shù)性質(zhì)。

詳細(xì)數(shù)學(xué)模型解釋?zhuān)?br />1)不難理解當(dāng)s=u+3*v+3*w時(shí),s除以3的余數(shù)與u除以3的余數(shù)是一樣的。
2)對(duì)s=cu+3*v+3*w,當(dāng)c除以3余數(shù)為1的數(shù)時(shí), s除以3的余數(shù)與u除以3的余數(shù)也是一樣的。證明如下:c 除以 3余數(shù)為1,記c=3*k+1,則s=u+3*k*u+3*v+3*w,由1)的結(jié)論,上述結(jié)論正確。記a,b,c分別為所猜數(shù)據(jù)d除以3,5,7后的余數(shù),則d=70*a+21*b+15*c。為問(wèn)題的數(shù)學(xué)模型,其中70稱(chēng)作a的系數(shù),21稱(chēng)作b的系數(shù),15稱(chēng)作c的系數(shù)。

問(wèn)題二,就單純是遞歸問(wèn)題,編者對(duì)于遞歸也不太熟悉,正在逐步探索中。

數(shù)學(xué)模型:
此問(wèn)題如果按照習(xí)慣,從前向后思考,也就是從第一階開(kāi)始,考慮怎么樣走到第二階、第三階、第四階……,則很難找出問(wèn)題的規(guī)律;而反過(guò)來(lái)先思考“到第n階有哪幾種情況?”,答案就簡(jiǎn)單了,只有兩種情況:
1) 從第n-1階到第n階;
2) 從第n-2階到第n階。
記n階臺(tái)階的走法數(shù)為f(n),則
f(n)= 1 n=1
f(n)=2 n=2
f(n-1)+f(n-2) n>2

代碼實(shí)現(xiàn)

主文件:main.m

%made by Canlong
%%
%編寫(xiě)算法完成下面給余猜謎的游戲
%心里想好一個(gè)1~100之間的整數(shù)x,將它分別除以3,5,7并得到3個(gè)余數(shù)。把這三個(gè)余數(shù)輸入計(jì)算機(jī),計(jì)算機(jī)能馬上猜出這個(gè)數(shù)。
%方法一:窮舉法
disp('方法一:窮舉法')
num1 = input('請(qǐng)輸入第一個(gè)數(shù):');
num2 = input('請(qǐng)輸入第二個(gè)數(shù):');
num3 = input('請(qǐng)輸入第三個(gè)數(shù):'); 
for i=1:100
    if rem(i,3)==num1 && rem(i,5)==num2 && rem(i,7)==num3  
       fprintf('該數(shù)為:%d \n',i); 
    end
end

%%
%方法二,建模.
disp('方法二,建模.');
num1 = input('請(qǐng)輸入第一個(gè)數(shù):');
num2 = input('請(qǐng)輸入第二個(gè)數(shù):');
num3 = input('請(qǐng)輸入第三個(gè)數(shù):'); 
d=70*num1+21*num2+15*num3;
while d>105
   d = d-105 ;
end
fprintf('該數(shù)為:%d \n',d);

%%
%斐波那契數(shù)列的應(yīng)用
%斐波那契數(shù)列有如下特點(diǎn):a1,a2已知  a(n)=a(n-1)+a(n-2)  n>=3
%例題:樓梯上有n階臺(tái)階,上樓時(shí)可以一步上1階,也可以一步上2階,編寫(xiě)算法計(jì)算共有多少種不同的上樓梯方法
%樓梯階數(shù)
n=10;
disp('如果樓梯階數(shù)為10,上樓梯的方法數(shù),解得:');
fprintf('f(%d)為:%d \n',n,f(n));


函數(shù)文件:f.m

%輸入n為階梯數(shù),a為返回的階梯數(shù)
%made by Canlong
function a=f(n)
    if n==1
         a=1;
         return;
    end
    if n==2
         a=2;
         return
    else
         a=f(n-1)+f(n-2);
         return
    end
end

運(yùn)行結(jié)果

在MATLAB R2015b軟件下運(yùn)行得到:

這里寫(xiě)圖片描述

總結(jié)

  太久沒(méi)用matlab寫(xiě)代碼了,對(duì)于matlab很多語(yǔ)法很多都不熟悉了,寫(xiě)到函數(shù)那里還以為return 數(shù)值會(huì)直接返回?cái)?shù)值,原來(lái)matlab的函數(shù),是通過(guò)某個(gè)變量來(lái)返回值的,不能直接return 數(shù)值,如function a=f(n)中的a就是用來(lái)接受返回?cái)?shù)值的,要返回?cái)?shù)值的函數(shù)一定要對(duì)a進(jìn)行賦值。這一點(diǎn)上與java等語(yǔ)言不太類(lèi)似。

到此這篇關(guān)于MATLAB算法技巧和實(shí)現(xiàn)斐波那契數(shù)列的文章就介紹到這了,更多相關(guān)MATLAB斐波那契數(shù)列內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言中實(shí)現(xiàn)自定義數(shù)據(jù)類(lèi)型的輸入輸出的方法和技巧

    C語(yǔ)言中實(shí)現(xiàn)自定義數(shù)據(jù)類(lèi)型的輸入輸出的方法和技巧

    在 C 語(yǔ)言中,除了基本的數(shù)據(jù)類(lèi)型(如整型、浮點(diǎn)型、字符型等),我們還經(jīng)常需要自定義數(shù)據(jù)類(lèi)型來(lái)滿(mǎn)足特定的編程需求,所以本文給大家介紹了C語(yǔ)言中實(shí)現(xiàn)自定義數(shù)據(jù)類(lèi)型的輸入輸出的方法和技巧,需要的朋友可以參考下
    2024-07-07
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之雙鏈表&循環(huán)鏈表&靜態(tài)鏈表詳解

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之雙鏈表&循環(huán)鏈表&靜態(tài)鏈表詳解

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)中雙鏈表&循環(huán)鏈表&靜態(tài)鏈表的原理與使用,文中的示例代碼講解詳細(xì),感興趣的可以了解一下
    2022-09-09
  • c++ sqlite3如何利用事務(wù)(BEGIN;COMMIT;)批量操作

    c++ sqlite3如何利用事務(wù)(BEGIN;COMMIT;)批量操作

    這篇文章主要介紹了c++ sqlite3如何利用事務(wù)(BEGIN;COMMIT;)批量操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C/C++?Qt?數(shù)據(jù)庫(kù)與TableView實(shí)現(xiàn)多組件聯(lián)動(dòng)

    C/C++?Qt?數(shù)據(jù)庫(kù)與TableView實(shí)現(xiàn)多組件聯(lián)動(dòng)

    Qt?數(shù)據(jù)庫(kù)組件與TableView組件實(shí)現(xiàn)聯(lián)動(dòng)效果,本文通過(guò)案例給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-12-12
  • C/C++?Qt?Tree與Tab組件實(shí)現(xiàn)分頁(yè)菜單功能

    C/C++?Qt?Tree與Tab組件實(shí)現(xiàn)分頁(yè)菜單功能

    這篇文章主要介紹了C/C++?Qt?Tree與Tab組件實(shí)現(xiàn)分頁(yè)菜單功能,實(shí)現(xiàn)一個(gè)類(lèi)似于樹(shù)形菜單欄的功能,當(dāng)用戶(hù)點(diǎn)擊菜單欄中的選項(xiàng)時(shí)則會(huì)跳轉(zhuǎn)到不同的頁(yè)面上,本文簡(jiǎn)單給大家分享實(shí)現(xiàn)代碼,感興趣的朋友跟隨小編一起看看吧
    2021-11-11
  • C++中的類(lèi)模板詳解及示例

    C++中的類(lèi)模板詳解及示例

    我們?cè)诙x函數(shù)時(shí),可以通過(guò)定義函數(shù)模板,來(lái)簡(jiǎn)化一些功能相同而數(shù)據(jù)類(lèi)型不同的函數(shù)的定義和調(diào)用過(guò)程
    2013-10-10
  • c++二叉樹(shù)的幾種遍歷算法

    c++二叉樹(shù)的幾種遍歷算法

    c++二叉樹(shù)的幾種遍歷算法,需要的朋友可以參考一下
    2013-02-02
  • C語(yǔ)言每日練習(xí)之冒泡排序

    C語(yǔ)言每日練習(xí)之冒泡排序

    這篇文章主要介紹了C語(yǔ)言冒泡排序,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-11-11
  • C語(yǔ)言詳解判斷相同樹(shù)案例分析

    C語(yǔ)言詳解判斷相同樹(shù)案例分析

    這篇文章主要介紹了用C語(yǔ)言檢查兩棵樹(shù)是否相同,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2022-04-04
  • C++ 單例模式的幾種實(shí)現(xiàn)方式研究

    C++ 單例模式的幾種實(shí)現(xiàn)方式研究

    單例模式,可以說(shuō)設(shè)計(jì)模式中最常應(yīng)用的一種模式了,據(jù)說(shuō)也是面試官最喜歡的題目。但是如果沒(méi)有學(xué)過(guò)設(shè)計(jì)模式的人,可能不會(huì)想到要去應(yīng)用單例模式,面對(duì)單例模式適用的情況
    2019-01-01

最新評(píng)論