国产精品天干天干,亚洲毛片在线,日韩gay小鲜肉啪啪18禁,女同Gay自慰喷水

歡迎光臨散文網(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ó)家法律
红河县| 南部县| 阳泉市| 杭州市| 老河口市| 辉县市| 江安县| 肃南| 兴文县| 五常市| 炎陵县| 体育| 平武县| 保康县| 北辰区| 沽源县| 河南省| 黔西县| 长武县| 平武县| 虞城县| 辽中县| 延吉市| 合川市| 昂仁县| 都江堰市| 青阳县| 陕西省| 依安县| 长武县| 临泉县| 应用必备| 东阳市| 苍梧县| 泰安市| 新建县| 石家庄市| 娄烦县| 扶风县| 伊宁县| 威远县|