什么是空语句?什么时候会用到空语句?
只含义一个单独的分号的语句是空语句。如:
;
如果在程序的某个地方,语法上需要一条语句但是逻辑上不需要,此时应该使用空语句。
while (cin >> s && s != sought);
什么是块?什么时候会用到块?
用花括号括起来的语句和声明的序列就是块。
{// ...
}
如果在程序的某个地方,语法上需要一条语句,而逻辑上需要多条语句,此时应该使用块
while (val <= 10) {sum += val;++val;
}
使用逗号运算符重写1.4.1节的 while 循环,使它不再需要块,观察改写之后的代码可读性提高了还是降低了。
while (val <= 10)sum += val, ++val;
代码的可读性反而降低了。
说明下列例子的含义,如果存在问题,试着修改它。
(a) while (string::iterator iter != s.end()) { /* . . . */ }
(b) while (bool status = find(word)) { /* . . . */ }if (!status) { /* . . . */ }
写一段自己的程序,使用if else 语句实现把数字转换为字母成绩的要求。
#include
#include
#include
using std::vector; using std::string; using std::cout; using std::endl; using std::cin;int main()
{vector scores = { "F", "D", "C", "B", "A", "A++" };for (int g; cin >> g;){string letter;if (g < 60){letter = scores[0];}else{letter = scores[(g - 50) / 10];if (g != 100)letter += g % 10 > 7 ? "+" : g % 10 < 3 ? "-" : "";cout << letter << endl;}}return 0;
}
改写上一题的程序,使用条件运算符代替if else语句。
#include
#include
#include
using std::vector; using std::string; using std::cout; using std::endl; using std::cin;int main()
{vector scores = { "F", "D", "C", "B", "A", "A++" };int grade = 0;while (cin >> grade){string lettergrade = grade < 60 ? scores[0] : scores[(grade - 50) / 10];lettergrade += (grade == 100 || grade < 60) ? "" : (grade % 10 > 7) ? "+" : (grade % 10 < 3) ? "-" : "";cout << lettergrade << endl;}return 0;
}
改写下列代码段中的错误。
(a) if (ival1 != ival2) ival1 = ival2else ival1 = ival2 = 0;
(b) if (ival < minval) minval = ival;occurs = 1;
(c) if (int ival = get_value())cout << "ival = " << ival << endl;if (!ival)cout << "ival = 0\n";
(d) if (ival = 0)ival = get_value();
ival1 = ival2
后面少了分号。if (!ival)
应该改为 else
。if (ival = 0)
应该改为 if (ival == 0)
。什么是“悬垂else”?C++语言是如何处理else子句的?
C++语言规定else与它最近的尚未匹配的if匹配。
编写一段程序,使用一系列if语句统计从cin读入的文本中有多少元音字母。
#include using std::cout; using std::endl; using std::cin;int main()
{unsigned aCnt = 0, eCnt = 0, iCnt = 0, oCnt = 0, uCnt = 0;char ch;while (cin >> ch){if (ch == 'a') ++aCnt;else if (ch == 'e') ++eCnt;else if (ch == 'i') ++iCnt;else if (ch == 'o') ++oCnt;else if (ch == 'u') ++uCnt;}cout << "Number of vowel a: \t" << aCnt << '\n'<< "Number of vowel e: \t" << eCnt << '\n'<< "Number of vowel i: \t" << iCnt << '\n'<< "Number of vowel o: \t" << oCnt << '\n'<< "Number of vowel u: \t" << uCnt << endl;return 0;
}
我们之前实现的统计元音字母的程序存在一个问题:如果元音字母以大写形式出现,不会被统计在内。编写一段程序,既统计元音字母的小写形式,也统计元音字母的大写形式,也就是说,新程序遇到’a’和’A’都应该递增 aCnt 的值,以此类推。
#include
using std::cin; using std::cout; using std::endl;int main()
{unsigned aCnt = 0, eCnt = 0, iCnt = 0, oCnt = 0, uCnt = 0;char ch;while (cin >> ch)switch (ch){case 'a':case 'A':++aCnt;break;case 'e':case 'E':++eCnt;break;case 'i':case 'I':++iCnt;break;case 'o':case 'O':++oCnt;break;case 'u':case 'U':++uCnt;break;}cout << "Number of vowel a(A): \t" << aCnt << '\n'<< "Number of vowel e(E): \t" << eCnt << '\n'<< "Number of vowel i(I): \t" << iCnt << '\n'<< "Number of vowel o(O): \t" << oCnt << '\n'<< "Number of vowel u(U): \t" << uCnt << endl;return 0;
}