五月天青色头像情侣网名,国产亚洲av片在线观看18女人,黑人巨茎大战俄罗斯美女,扒下她的小内裤打屁股

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

第3講 循環(huán)結(jié)構(gòu)

2023-03-02 10:42 作者:踏月隨舟盡西風(fēng)  | 我要投稿

學(xué)習(xí)編程語(yǔ)言語(yǔ)法是次要的,思維是主要的。如何把頭腦中的想法變成簡(jiǎn)潔的代碼,至關(guān)重要。

學(xué)習(xí)循環(huán)語(yǔ)句只需要抓住一點(diǎn)——代碼執(zhí)行順序!

一、while循環(huán)

可以簡(jiǎn)單理解為循環(huán)版的if語(yǔ)句。if語(yǔ)句是判斷一次,如果條件成立,則執(zhí)行后面的語(yǔ)句;while是每次判斷,如果成立,則執(zhí)行循環(huán)體中的語(yǔ)句,否則停止。

練習(xí):求1~100中所有數(shù)的立方和。

公式推導(dǎo) https://www.bilibili.com/video/BV1P741117QQ/?spm_id_from=333.999.0.0

設(shè)1^3+2^3+…n^3=P(n)兩邊取導(dǎo)數(shù)得

3(1^2+2^2+…+n^2)=P(n)的導(dǎo)數(shù)

由于1^2+2^2+…+n^2=1/6n(n+1)(2n+1)

所以P(n)的導(dǎo)數(shù)=1/2n(n+1)(2n+1)=1/2(2n^3+3n^2+n)

再對(duì)1/2(2n^3+3n^2+n)取積分得1/4(n^4+2n^3+n^2)+C(C為常數(shù))

化簡(jiǎn)得((1+n)n/2)^2+C

將n=1代入 由((1+n)n/2)^2+C=1得C=0

所以P(n)=((1+n)n/2)^2

推導(dǎo)

練習(xí):求斐波那契數(shù)列的第n項(xiàng)。f(1) = 1, f(2) = 1, f(3) = 2, f(n) = f(n-1) + f(n-2)。

死循環(huán):循環(huán)永久執(zhí)行,無(wú)法結(jié)束。我們要避免寫(xiě)出死循環(huán)。

二、do while循環(huán)

do while循環(huán)不常用。

do while語(yǔ)句與while語(yǔ)句非常相似。唯一的區(qū)別是,do while語(yǔ)句限制性循環(huán)體后檢查條件。不管條件的值如何,我們都要至少執(zhí)行一次循環(huán)。

三、for循環(huán) 具象

基本思想:把控制循環(huán)次數(shù)的變量從循環(huán)體中剝離。

init-statement可以是聲明語(yǔ)句、表達(dá)式、空語(yǔ)句,一般用來(lái)初始化循環(huán)變量;

condition是條件表達(dá)式,和while中的條件表達(dá)式作用一樣;可以為空,空語(yǔ)句表示true;

expression一般負(fù)責(zé)修改循環(huán)變量,可以為空。

練習(xí):求1~100中所有數(shù)的立方和。

練習(xí):求斐波那契數(shù)列的第n項(xiàng)。f(1) = 1, f(2) = 1, f(3) = 2, f(n) = f(n-1) + f(n-2)。

init-statement可以定義多個(gè)變量,expression也可以修改多個(gè)變量。

例如求 1 * 10 + 2 * 9 + 3 * 8 + 4 * 7 + 5 * 6:

四、跳轉(zhuǎn)語(yǔ)句

1. break

可以提前從循環(huán)中退出,一般與if語(yǔ)句搭配。

例題:判斷一個(gè)大于1的數(shù)是否是質(zhì)數(shù):

2. continue

可以直接跳到當(dāng)前循環(huán)體的結(jié)尾。作用與if語(yǔ)句類(lèi)似。

例題:求1~100中所有偶數(shù)的和。

五、多層循環(huán)

英語(yǔ)需要背因?yàn)樵O(shè)計(jì)語(yǔ)言的時(shí)候有很多特例,編程語(yǔ)言由數(shù)學(xué)家設(shè)計(jì)很精妙只記規(guī)則

練習(xí):打印1~100中的所有質(zhì)數(shù)

練習(xí):輸入一個(gè)n,打印n階菱形。n是奇數(shù)。

n = 9時(shí)的結(jié)果: 曼哈頓距離? 歐幾里得距離


注:

  1. 讀入的個(gè)數(shù)未知時(shí),可以用while(cin >> x)或while(scanf("%d", &x) != -1)或while(~scanf("%d", &x))來(lái)輸入。如果輸入的最后一個(gè)為0且該0不處理,輸入語(yǔ)句可以用while(cin >> x && x)或while(cin >> x, x),逗號(hào)表達(dá)式取最后一個(gè)值。

  2. DEV 編譯選項(xiàng)里加-std=c++14

  3. 一般來(lái)講由于遞歸不存儲(chǔ)中間結(jié)果,所以遞歸的效率應(yīng)該是比循環(huán)低,但程序員效率高


第3講 循環(huán)結(jié)構(gòu)的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國(guó)家法律
时尚| 安塞县| 马鞍山市| 揭东县| 栾城县| 恩施市| 永登县| 上虞市| 徐汇区| 晋中市| 南昌市| 苏尼特左旗| 安陆市| 弥渡县| 米泉市| 廊坊市| 杨浦区| 东明县| 寻甸| 新晃| 南投县| 公主岭市| 博客| 双江| 天水市| 武义县| 深水埗区| 阿克苏市| 西宁市| 错那县| 大竹县| 兴国县| 科尔| 丽江市| 宜宾县| 兴山县| 海伦市| 绵阳市| 开化县| 睢宁县| 清镇市|