990 likes | 1.2k Views
目標 了解基本解決問題的技巧 能夠發展出完整的從上到下,可進行逐步細部修改過程的演算法 能夠使用 if , if/else 和 switch 等選擇結構,在各種動作選項中選取適合的動作 能夠使用 while , do/while 和 for 等重複結構,在程式中重複執行一些敘述式 了解計數器控制迴圈 (counter-controlled repetition) 和旗標訊號控制迴圈 (sentinel-controlled repetition) 能夠使用遞增、遞減、指定和邏輯運算子 能夠使用 break 和 continue 等程式控制敘述式.
E N D
目標 了解基本解決問題的技巧 能夠發展出完整的從上到下,可進行逐步細部修改過程的演算法 能夠使用if, if/else和switch等選擇結構,在各種動作選項中選取適合的動作 能夠使用while, do/while和for等重複結構,在程式中重複執行一些敘述式 了解計數器控制迴圈(counter-controlled repetition) 和旗標訊號控制迴圈(sentinel-controlled repetition) 能夠使用遞增、遞減、指定和邏輯運算子 能夠使用break和continue等程式控制敘述式 Chapter 2 – 控制結構
Chapter 2 – 控制結構 大綱 2.1簡介2.2Algorithms演算法2.3Pseudocode虛擬碼2.4Control Structures控制結構2.5 if選擇結構2.6if/else選擇結構 2.7while重複結構 2.8 演算法的規劃:範例研究一2.9從上到下,逐步細部修改的演算法規劃:範例研究二2.10 從上到下,逐步細部修改的演算法規劃:範例研究三2.11 Assignment Operators指定運算子2.12 Increment and Decrement Operators遞增和遞減運算子2.13 計數器控制迴圈的基本原理2.14 for重複結構2.15 使用for結構的範例
Chapter 2 – 控制結構 大綱 2.16 switch多重選擇結構2.17 do/while重複結構2.18 break與continue敘述式2.19 邏輯運算子2.20 等號運算子(==) 與指定運算子 (=) 的混淆2.21 結構化程式設計的總結 2.22 (選讀性的範例研究)物件的探索:辨識問題中的類別
2.1 簡介 • 在寫程式之前: • 對問題有個通盤的了解 • 謹慎計劃解決此問題的方式 • 開始寫程式時: • 需要知道有哪些「程式區段」可以使用 • 要使用好的程式設計觀念
2.2 Algorithms演算法 • 所有的計算問題 • 可藉由執行一系列經特殊安排的動作加以解決。 • 解決問題的程序即所謂的 Algorithm演算法 • 包括: • Actions to be executed (要作的動作) • 這些動作的執行順序 • Program control 程式 控制 • 指定程式中敘述式的執行順序 起床、脫掉睡衣、洗澡、穿衣服、吃早餐、坐公車上班 起床、脫掉睡衣、穿衣服、洗澡、吃早餐、坐公車上班
2.3 Pseudocode虛擬碼 • Pseudocode(虛擬碼) • 是人工的、非正式的語言,主要功用是發展演算法 • 類似日常用的英文 • 並不能在電腦上實際執行 • 其功用是幫助程式設計者在寫程式之前,先「想出」程式該怎麼寫。 (這是演算法、虛擬碼的目的) • 可以很容易地轉換為相對的 C++ 程式 • 只由可以執行的敘述式組成 (不包含變數宣告)
2.4 Control Structures控制結構 • Sequentialexecution 循序執行 • 敘述式按順序從上到下執行。 • Transfer of control 控制權轉移 • 接下來要執行的敘述式不按順序 • 早期控制權轉移的指令是 goto:可轉移到(幾乎)任何地方去。 • Structured programming ≡ goto elimination • Bohm 和 Jacopini 證明所有程式都可只用三種控制結構寫 • Sequencestructure 循序結構 • C++ 內定的執行方式 • Selectionstructures 選擇結構 • C++ 有三種型態 - if, if/else, 與 switch • Repetitionstructures 重複結構 • C++ 有三種型態 - while, do/while, 與 for
2.4 Control Structures控制結構 • C++ 關鍵字 • 不能被當作識別字或變數名稱的字
2.4 Control Structures控制結構 • Flowchart 流程圖 • 用圖形來表示演算法 • 用一些特殊涵義的圖示(如:矩形、菱形、橢圓、小圓圈)表示所要執行的動作、用箭號連接。 • 矩形表示動作(任何型態的動作,包括輸入、輸出) • 橢圓形表示程式的開始與結束 • 小圓圈表示一段程式的開始與結束 • 單一入口/單一出口 的控制結構 • 將一個控制結構的出口點接到下個控制結構的入口 (堆疊式控制結構). • 使程式更容易建立
true false print “Passed” grade >= 60 2.4 Control Structures控制結構 常見的程式設計錯誤 2.1 • 將關鍵字當作識別字使用是語法錯誤。 軟體工程的觀點 2.1 • 任何 C++ 程式都可以只用七種控制結構來建立,包括: if, if/else, switch, while, do/while, for,且只用兩種方式來組成(控制結構堆疊排列和控制結構巢狀排列)
2.5 if選擇結構 • 選擇結構 • 在不同的 actions 間作選擇 • 虛擬碼的例子: If student’s grade is greater than or equal to 60 Print “Passed” • 若條件為 true • print 敘述式會被執行,之後再執行下個敘述。 • 若條件為 false • print 敘述式會被忽略,直接執行下個敘述。 • 縮排比較容易閱讀 • C++ 的編譯器會忽略空格字元(whitespace characters),包括:空白、定位(tab)、新行(newline)等字元。
2.5 if 選擇結構 • 將虛擬碼轉換為 C++ 敘述: if ( grade >= 60 ) cout << "Passed"; • 菱形符號 (decision symbol) • 表示要作決定 • 包含要作判斷的運算式(條件) • 測試條件是否成立、執行適當的敘述 • if結構是單一入口/單一出口的結構 • C 語言中的條件是否成立:以運算式結果為 0 的話就代表不成立,否則就成立。而 C++ 可以宣告bool型態的變數,此型態變數的內容只可能是true或 false。
運算式結果代表: 零 - false 非零 - true 例如: 3 - 4是true true false print “Passed” grade >= 60 2.5 if 選擇結構 • 前面虛擬碼的流程圖 • 良好的程式設計習慣 2.1-2.2 • 在程式中採用統一的內縮量,可以大幅增加程式的可讀性。建議用固定大小的內縮量( ¼ 英吋或三格)
2.6 if/else選擇結構 • if • 只有當條件成立時才執行某個動作 • if/else • 當條件成立執行一個動作,條件不成立執行另一個動作 (two-way selection 二選一) • 虛擬碼 if student’s grade is greater than or equal to 60print “Passed” else print “Failed” • C++ 程式碼 if ( grade >= 60 ) cout << "Passed";else cout << "Failed";
Condition Value if true Value if false false true print “Passed” print “Failed” grade >= 60 2.6 if/else選擇結構 • 三元條件運算子 (?:) • 有三個引數、運算元 (條件, value if true, value if false) • 前面的虛擬碼可改寫成: cout << ( grade >= 60 ? “Passed” : “Failed” ); grade >= 60 ? cout << “Passed”: cout << “Failed”;
2.6 if/else選擇結構 • 巢狀 if/else結構 (重疊式) • 將if/else放在另一個 if/else選擇結構中,可以測試多種狀況,達到多選一的效果 if student’s grade is greater than or equal to 90 Print “A”else if student’s grade is greater than or equal to 80 Print “B” else if student’s grade is greater than or equal to 70 Print “C” else if student’s grade is greater than or equal to 60 Print “D” else Print “F” • 只要一個條件成立、其餘的都被跳過 P.21
2.6 if/else選擇結構 if (grade >= 90) cout << “A”; elseif (grade >= 80) cout << “B”; elseif (grade >= 70) cout << “C”; elseif (grade >= 60) cout << “D”; else cout << “F”; • 多選一的寫法。 • 可以用 switch。
2.6 if/else選擇結構 • Compoundstatement(複合敘述式) • 將好幾個敘述用大括號包起來,成為一個複合敘述式 • 例如:: if ( grade >= 60 ) cout << “Passed.\n”; else { //要記得加括號cout << "Failed.\n"; cout << "You must take this course again.\n";} • 如果沒有加大括號的話 cout << "You must take this course again.\n"; 就一定會被執行。 • Block • 複合敘述式加上變數宣告
2.6 if/else選擇結構 • Syntax errors // 語法錯誤,compiler 看不懂。 • 由編譯器引起的錯誤 • Logic errors //邏輯錯誤,執行結果有錯誤 • Errors which have their effect at execution time • Non-fatal logic errors //非致命錯誤,可執行完,結果錯誤 • program runs, but has incorrect output • Fatal logic errors //致命錯誤,執行到一半被強迫停止。 • program exits prematurely
良好的程式設計習慣 2.2-2.5 • 將 if/else結構的兩個本體敘述式都予以縮排處理 • 如果需要安排好幾層的縮排,每層都用相同的縮排量 • 在if/else結構(或任何控制結構) 中,先放入一對大括號,這樣就能預防不小心遺漏的問題發生,特別是後來再加入if或 else的情形。 • 有些程式設計者寫程式時,會先將複合敘述的左右大括號一次先打好,可避免遺漏的情形。 軟體工程的觀點 2.2 • 複合敘述式(compound statement)可以放在任何單行敘述式可出現的地方。
增進效能的小技巧 2.1-2.2 • 巢狀if/else結構的執行速度會比一連串個別選擇的 if結構更快,因為前者只要條件一符合就可能提早結束 • 在巢狀if/else結構中,儘量將可能成立的條件放在巢狀if/else結構的開端。這樣執行速度比較快,因為條件成立後就不必再測試其他情形了。 常見的程式設計錯誤 2.3-2.4 • 如果忘記加上大括號的任一邊,就無法限制複合敘述式的範圍,就會導致程式出現語法錯誤或者邏輯錯誤。 • 若在if結構的條件式後面多放一個分號,這會讓單選擇的if結構產生邏輯錯誤,會讓雙選擇的 if結構產生語法錯誤(若在 if的部份包含一個實際的敘述式).
2.7 while 重複結構 • 重複結構 • 程式設計者指定在某條件持續成立時、重複執行某個動作 • 虛擬碼 while there are more items on my shopping list Purchase next item and cross it off my list • while迴圈一直重複到條件不成立為止 • 例如: int product = 2; while ( product <= 1000 ) product = 2 * product; while 的 body 可以是單一的 statement 或是一個 compound statment product最後變成 1024 才結束。
true product <= 1000 product = 2 * product false 2.7 while 重複結構 • while迴圈的流程圖 • 常見的程式設計錯誤 2.5 • 若在while結構的本體裡面沒提供最後會造成while條件變成false的動作,這一般會產「無窮迴圈」的錯誤,也就是重複結構永遠不會終止。 • 若將關鍵字 while拼成大寫字母的While(記得 C++ 是大小寫有別的語言),就是語法錯誤。所有 C++ 的關鍵字都只包含小寫字母,例如:while, if和 else。
2.8 Formulating Algorithms (Counter-Controlled Repetition) • Counter-controlled repetition 計數控制重複結構 • 迴圈重複執行到計數器達到特定值為止 • Definite repetition 明確的重複 • 重複次數事先知道 • 例如: A class of ten students took a quiz. The grades (integers in the range 0 to 100) for this quiz are available to you. Determine the class average on the quiz. 十個人的班級舉行小考,輸入每個人的分數(0-100的整數),請計算這次小考的平均分數。
2.8 Formulating Algorithms (Counter-Controlled Repetition) • 此範例的虛擬碼 Set total to zero Set grade counter to one While grade counter is less than or equal to ten Input the next grade Add the grade into the total Add one to the grade counter Set the class average to the total divided by tenPrint the class average • 下面是此範例的 C++ 程式碼
1 // Fig. 2.7: fig02_07.cpp 2 // Class average program with counter-controlled repetition 3 #include <iostream> 4 5 using std::cout; 6 using std::cin; 7 using std::endl; 迴圈每執行一次 counter 就增加 1,最後 counter 的值導致迴圈結束 8 9 int main() 10 { 11 int total, // sum of grades 12 gradeCounter, // number of grades entered 13 grade, // one grade 14 average; // average of grades 15 16 // initialization phase 17 total = 0; // clear total 18 gradeCounter = 1; // prepare to loop 19 20 // processing phase 21 while ( gradeCounter <= 10 ) { // loop 10 times 22 cout << "Enter grade: "; // prompt for input 23 cin >> grade; // input grade 24 total = total + grade; // add grade to total 25 gradeCounter = gradeCounter + 1; // increment counter 26 } 27 28 // termination phase 29 average = total / 10; // integer division 30 cout << "Class average is " << average << endl; 31 32 return 0; // indicate program ended successfully 33 } 1. Initialize Variables 2. Execute Loop 3. Output results
Enter grade: 98 Enter grade: 76 Enter grade: 71 Enter grade: 87 Enter grade: 83 Enter grade: 90 Enter grade: 57 Enter grade: 79 Enter grade: 82 Enter grade: 94 Class average is 81 Program Output 總分是 817,但平均為整數,所以結果是 81。 • 常見的程式錯誤 2.6-2.7 • 若 counter 或 total 沒有作初始化,你程式的結果很可能不正確,這是邏輯錯誤。 • 迴圈結束後,將 counter variable 的值拿來用時,需仔細考慮其值的大小,有時會差 1。例如前面例子中,將總分除以人數時,若將 gradeCounter 當作人數會差 1,. • 良好的程式設計習慣 2.6 • 將代表計數器與總合的變數都作初始化。
2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈)2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈) • 讓我們將前面的問題一般化 Develop a class-averaging program that will process an arbitrary number of grades each time the program is run. 寫一個計算全班平均分數的程式,班級的人數可以任意 • 不知道學生人數 - 如何知道程式何時要停止? • Sentinel value(檢查值、旗標值) • 指出資料結束 • 當旗標被輸入時,迴圈也必須結束 • 選擇一個適當的值當旗標,旗標必須與正常的資料不同(這例子中可以用 –1 當旗標)
2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈)2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈) • 從上到下、逐步細部修改 • 一開始只用單獨一行敘述如下: Determine the class average for the quiz(計算小考全班平均分數) • 分成比較小的工作、並按順序寫下來: Initialize variables(初始化變數) Input, sum and count the quiz grades(輸入、計算人數、總分) Calculate and print the class average (計算並印出平均分數)
2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈)2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈) • 很多程式都可以分成三個部份 • Initialization 初始化 • 將程式變數作初始化 • Processing 處理 • 輸入資料、並適當地調整變數內容 • Termination 停止 • 計算並印出最後結果 • 將初始化的步驟分成更小的細節 Initialize variables to Initialize total to zero (total 初始設為 0) Initialize counter to zero (counter 初始設為 0)
2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈)2.9 利用從上到下,逐步細部修改的演算法規劃:範例研究二(旗標訊號控制迴圈) • 精煉 Input, sum and count the quiz grades to Input the first grade (possibly the sentinel) While the user has not as yet entered the sentinel Add this grade into the running total Add one to the grade counter Input the next grade (possibly the sentinel) • 精煉 Calculate and print the class average to If the counter is not equal to zero Set the average to the total divided by the counter Print the average Else Print “No grades were entered”
1 // Fig. 2.9: fig02_09.cpp 2 // Class average program with sentinel-controlled repetition. 要作一些格式化輸出的操作時,必須 #include <iomanip> 資料型態 double用來存放十進位含小數的資料 3 #include <iostream> 4 5 using std::cout; 6 using std::cin; 7 using std::endl; 8 using std::ios; 9 10 #include <iomanip> 11 12 using std::setprecision; 13 using std::setiosflags; 14 15 int main() 16 { 17 int total, // sum of grades 18 gradeCounter, // number of grades entered 19 grade; // one grade 20 double average; // number with decimal point for average 21 22 // initialization phase 23 total = 0; 24 gradeCounter = 0; 25 26 // processing phase 27 cout << "Enter grade, -1 to end: "; 28 cin >> grade; 29 30 while ( grade != -1 ) { 1. Initialize Variables 2. Get user input 2.1 Perform Loop
31 total = total + grade; static_cast<double>() – 將 total暫時當成 double來對待 這是必須的,因為兩個整數相除的結果也是整數,小數部份會被自動捨棄 gradeCounter是 int, 但在這裡會被升級為o double. 32 gradeCounter = gradeCounter + 1; 33 cout << "Enter grade, -1 to end: "; 34 cin >> grade; 35 } setiosflags(ios::fixed | ios::showpoint)– 串流操作者 ios::fixed – 用定點式的十進位小數點方式輸出數字 ios::showpoint – 強制十進位小數尾端補 0,甚至不需要時。例如:66會輸出 66.00 | - 分開多項選擇. 36 37 // termination phase 38 if ( gradeCounter != 0 ) { setprecision(2) – 精確度到小數點以下第二位 要用這功能必須先 #include <iomanip> 39 average = static_cast< double >( total ) / gradeCounter; 40 cout << "Class average is " << setprecision( 2 ) 41 << setiosflags( ios::fixed | ios::showpoint ) 42 << average << endl; 43 } 44 else 45 cout << "No grades were entered" << endl; 46 47 return 0; // indicate program ended successfully 48 } 3. Calculate Average 3.1 Print Results Program Output Enter grade, -1 to end: 75 Enter grade, -1 to end: 94 Enter grade, -1 to end: 97 Enter grade, -1 to end: 88 Enter grade, -1 to end: 70 Enter grade, -1 to end: 64 Enter grade, -1 to end: 83 Enter grade, -1 to end: 89 Enter grade, -1 to end: -1 Class average is 82.50
常見的程式設計錯誤 2.8~2.10 • 若選取的檢查值也是合法的資料數值,就是邏輯錯誤。 • 企圖除以 0 時會造成致命錯誤。 • 使用浮點數時假設它是用精確的方式來儲存會造錯誤的結果,大部份電腦的浮點數是用近似的方式儲存。 • 避免錯誤的小技巧 2.2 • 執行除法時,若除數(式)的值可能為 0,請以適合的方式明確地先測試這個狀況是否發生(就可在錯誤發生時,印出錯誤訊息),而不是任由發生致命錯誤。 • 良好的程式設計習慣 2.7 • 每次要使用者輸入資料時,都給予提示。提示內容必須指明輸入的方式,和任何特殊的輸入值(例:使用者必須輸入用來結束迴圈之用的旗標值)
2.10 巢狀控制結構 • 問題: A college has a list of test results (1 = pass, 2 = fail) for 10 students. Write a program that analyzes the results. If more than 8 students pass, print “Raise Tuition“(調高學費). • 我們可觀察到: • 這個程式必須處理十個測驗結果,可用計數控制迴圈的方式 • 每個測驗結果都是數字 — 不是 1就是 2,若輸入不是 1, 就假設是 2。 • 用兩個計數器 - 分別計算 passed 與 failed 的人數 • 開始分析的虛擬碼: Analyze exam results and decide if tuition should be raised (分析考試結果並決定學費是否調漲)
2.10 巢狀控制結構 • 第一次細部修改 Initialize variables Input the ten quiz grades and count passes and failures Print a summary of the exam results and decide if tuition should be raised • 第二次細部修改 Initialize variables to Initialize passes to zero Initialize failures to zero Initialize student counter to one
2.10 巢狀控制結構 • 細部修改 Input the ten quiz grades and count passes and failures to While student counter is less than or equal to tenInput the next exam result If the student passed Add one to passesElse Add one to failures Add one to student counter • 細部修改 Print a summary of the exam results and decide if tuition should be raised to Print the number of passes Print the number of failures If more than eight students passed Print “Raise tuition”
1 // Fig. 2.11: fig02_11.cpp 2 // 分析考試結果 3 #include <iostream> 4 5 using std::cout; 6 using std::cin; 7 using std::endl; 8 9 int main() 10 { 11 // initialize variables in declarations 12 int passes = 0, // passes 的人數 13 failures = 0, // failures 的人數 14 studentCounter = 1, // 學生計數 15 result; // 一個考試結果 16 17 // process 10 students; counter-controlled loop 18 while ( studentCounter <= 10 ) { 19 cout << "Enter result (1=pass,2=fail): "; 20 cin >> result; 21 22 if ( result == 1 ) // while 裡面的 if/else 結構 23 passes = passes + 1; 1. Initialize variables 2. Input data and count passes/failures
24 else 25 failures = failures + 1; 26 27 studentCounter = studentCounter + 1; 28 } 29 30 // termination phase 31 cout << "Passed " << passes << endl; 32 cout << "Failed " << failures << endl; 33 34 if ( passes > 8 ) 35 cout << "Raise tuition " << endl; 36 37 return 0; // successful termination 38 } 3. Print results Program Output
Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 2 Enter result (1 = pass, 2 = fail): 2 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 2 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 2 Passed 6 Failed 4 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 2 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Enter result (1 = pass, 2 = fail): 1 Passed 9 Failed 1 Raise tuition 3. Print results Program Output
良好的程式設計習慣 2.8 • 在變數宣告時順便初始化,可以避免忘記作初始化所帶來的問題。 軟體工程的觀點 2.6~2.7 • 經驗顯示利用電腦解決問題最困難的地方是,如何設計出該問題的演算法,一旦演算法想出來,就可以從演算法直接導出可執行的 C++ 程式。 • 很多有經驗的程式設計者寫程式時都不用虛擬碼,他們認為最終目的就是在電腦上解決問題,寫虛擬碼只是浪費時間。這種想法對一些簡單和常見的問題是實情,但是當要寫大型或複雜的系統時,就會導致嚴重的錯誤和時間的耽擱。
2.11指定運算子 • 縮短指定運算式 c = c + 3;可以縮寫為c += 3;使用加法指定運算子 • 指定運算子的格式 variable = variable operator expression; 可寫成 variable operator= expression; • 其他指定運算子的例子如下: • int c=3, d=5, e=4, f=6, g=12; d -= 4 (d = d - 4) e *= 5 (e = e * 5) f /= 3 (f = f / 3) g %= 9 (g = g % 9)
增進效能的小技巧 2.3-2.4 • 使用「縮寫式」的指定運算子,程式設計師可以更快的速度撰寫程式,而編譯器也能以更快速度編譯程式。如果使用「縮寫式」的指定運算子,某些編譯器會產生出更快執行速度的程式碼。 • 許多我們在此書中提到的執行上的小技巧,只會將程式改善一點點,因此讀者可能想要忽略使用。但是在一個會重複執行許多次迴圈上的小小改善,可能會在執行效率上產生極大的改進。
2.12遞增和遞減運算子 • 遞增運算子 (++) – 可以用來取代c += 1 • 遞減運算子 (--) – 可以用來取代c -= 1 • 前置遞增(減) • 運算子放在變數前面 (++c或––c) • 變數內容先遞增(減),然後才計算運算式的結果 • 後置遞增(減) • 運算子放在變數後面 (c++或c--) • 運算式的內容先計算出來,再將變數加(減) 1 • 例如:若c = 5則 • cout << ++c;會輸出6 (c先改變再用cout輸出) • cout << c++;會輸出5 (cout先執行後c的內容再增加,此敘述執行完後 c的值變成6)
2.12遞增和遞減運算子 • 若變數不是在運算式中 • 前置遞增(減)與後置遞增(減)的結果相同 ++c; cout << c; 與 c++; cout << c; 有相同的結果。 c++; ++c; c += 1; c = c + 1;有同樣的效果。
1 // Fig. 2.14: fig02_14.cpp 2 // Preincrementing and postincrementing. 3 #include <iostream> 4 5 using std::cout; 6 using std::endl; 7 8 // function main begins program execution 9 int main() 10 { 11 int c; // declare variable 12 13 // demonstrate postincrement 14 c = 5; // assign 5 to c 15 cout << c << endl; // print 5 16 cout << c++ << endl; // print 5 then postincrement 17 cout << c << endl << endl; // print 6 18 19 // demonstrate preincrement 20 c = 5; // assign 5 to c 21 cout << c << endl; // print 5 22 cout << ++c << endl; // preincrement then print 6 23 cout << c << endl; // print 6 3. Print results Program Output
24 25 return0; // indicate successful termination 26 27 } // end function main 3. Print results Program Output 5 5 6 5 6 6
2.12遞增和遞減運算子 良好的程式設計習慣 2.9 • 一元運算子應該緊跟著運算元,其間不要有任何空格。 常見的程式設計錯誤 2.11 • 企圖對不是單獨變數名稱的運算式進行遞增或遞減的運算,例如:寫成++(x+1)這是語法錯誤。
優先順序 運算子 結合性 () 從左至右 ++ -- static_cast<type>() 從右至左(前置) ++ -- + -(一元) 從左至右(後置) * / % 從左至右 + - 從左至右 << >> 從左至右 < <= > >= 從左至右 == != 從左至右 ?: 從左至右 = += -= *= /= %= 從右至左 , 從左至右
2.13 計數器控制迴圈的基本原理 • 計數器控制迴圈需要下述的條件: • 控制變數(或稱迴圈計數器)的名稱 • 控制變數的初值 • 測試控制變數終值(final value)的條件(就是判定迴圈是否要繼續執行的式子) • 決定在每次迴圈中,控制變數需要遞增(或遞減)的量 • 例如: int counter =1; //初值 while (counter <= 10){ //重複condition cout << counter << endl; ++counter; //遞增 }