最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(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ó)家法律
视频| 米泉市| 凯里市| 黔南| 云南省| 宁明县| 大安市| 磐安县| 靖安县| 松原市| 延川县| 道孚县| 三亚市| 东明县| 宁河县| 博爱县| 大竹县| 通河县| 通道| 苍山县| 沅陵县| 绩溪县| 新乡县| 原平市| 霍邱县| 库尔勒市| 荣昌县| 宜良县| 华蓥市| 阿拉善盟| 大丰市| 建阳市| 乌兰浩特市| 锦屏县| 称多县| 罗定市| 嘉定区| 凤翔县| 枝江市| 鄄城县| 大悟县|