if 语句回根据对某个条件的判断结果,将程序的流程分为两支。
- if-else 嵌套
- switch 语句
if-else 嵌套
多路分支的第一种实现方法就是使用 if-else 嵌套,即在 if 分支和(或者) else 分支中再嵌套 if-else 语句。
例如:
cin >> angle; // 输入角度
if (angle % 90 == 0)
{
// if-else嵌套
if (angle % 180 == 0)
cout << "线段在X轴上" << endl;
else
cout << "线段在Y轴上" << endl;
}
else
cout << "线段在象限" << angle / 90 + 1 << endl;
该程序计算输入的角度 angle 落在哪个象限或者哪个轴上。当输入的角度是90的倍数时(angle % 90 == 0为真),有两种情况,或者在X轴上,或者在Y轴上,所以需要其它条件(angle % 180 == 0)再次判断进行区分处理。
上面程序通过 if-else 嵌套实现了三路分支。
switch 语句
另一种实现多路分支的方法是使用 switch 语句, 格式如下:
switch(<条件表达式>)
{
case <常量表达式1>:
<语句序列1>;
case <常量表达式2>:
<语句序列2>;
……
case <常量表达式n>:
<语句序列n>;
default:
<语句序列n+1>;
}
其中,switch 、case 和 default 都是 C++ 的关键字。<条件表达式>是值为整型的表达式;每个 case 对应一个分支处理;default 分支为默认处理分支;<常量表达式1>……<常量表达式n>都是值为整型常量的表达式;<语句序列1>……<语句序列n+1>都是一组语句,可以为空。
执行流程
switch 语句执行流程如下:
switch 语句执行时,首先计算<条件表达式>得到一个整型的值,将该值与<常量表达式1>……<常量表达式n>的值逐个进行比较,如果与其中一个相等,则执行该常量表达式下的语句序列。
需要注意的是执行完该常量表达式对应的语句序列后,还将继续执行后续分支的处理语句序列,直到 switch 语句结束或者遇到跳转指令(break);如果测试表达式的值不与任何一个常量表达式的值相等,则执行 default 分支后面的语句。
switch 语句与 break
当一个 case 分支条件得到满足时,执行完该分支的语句序列后,还将继续执行后续分支的处理语句序列。如果希望执行完一个分支后就结束整个 switch 语句,可以在每个分支语句后面都加上一条 break 语句。
break 语句是一种转移语句,只能出现在 switch 结构和循环结构中。break 语句可以跳出直接包含该 break 语句的 switch 结构或循环结构(只能跳出一层),程序控制离开该 switch 结构或循环结构,执行其后继语句。
带 break 语句的 switch 语句模式如下:
switch(<条件表达式>)
{
case <常量表达式1>:
<语句序列1>;
break;
case <常量表达式2>:
<语句序列2>;
break;
……
case <常量表达式n>:
<语句序列n>;
break;
default:
<语句序列n+1>;
}
其执行过程为:首先计算<条件表达式>,将得到的整型值与<常量表达式1>……<常量表达式n>的值逐个进行比较,一旦检测到与其中一个相等,则执行该常量表达式下的语句序列,执行完后,紧接着就执行 break 语句,离开该 switch 结构,不再执行后续分支的处理语句序列,转向执行整个 switch 语句的后继语句。
例如下面的程序将百分制转换成十分制输出。如输入85,计算 scorePhrase 为8,则执行 switch 语句后进入case 8:分支,输出‘B’,然后执行 break ;语句跳出整个 switch 语句:
cin >> score; // 输入百分制分数
scorePhrase = score / 10; // 计算分数段,转换成十分制
// 判断并输出等级
switch (scorePhrase)
{
case 10:
case 9:
cout << 'A' << endl;
break;
case 8:
cout << 'B' << endl;
break;
case 7:
cout << 'C' << endl;
break;
case 6:
cout << 'D' << endl;
break;
case 0: case 1: case 2: case 3: case 4: case 5:
cout << 'E' << endl;
break;
default:
cout << "The score is illegal!" << endl;
}
程序: 通过输入的日期(数据由平台提供,以“年 月 日”的形式表示,需要你获取后使用)来判断该天是当年的第几天的要求。具体要求如下:
对于输入一个日期(年月日之间以一个空格间隔),形如2017 6 15,计算这一天是这一年的第几天并输出;
输出形式为“年-月-日是第X天”(其中 X 是你的计算结果)。
提示:本题计算思路比较清晰,例如 6 月 15 日就需要把前 5 个月的天数全部加上再加上 15 , 5 月 3 日则只需要加满前四个月的天数再加上 3 ,所以本题的计算根据月份不同而方法不同,需要考虑闰年。
测试输入:
2017 6 15
预期输出:
2017-6-15是第166天
测试输入:
2000 10 1
预期输出:
2000-10-1是第275天
// 包含两种I/O库,可以使用任一种输入输出方式
#include <stdio.h>
#include <iostream>
using namespace std;
int main()
{
// y-年,m-月,d-日,n-第几天
int y, m, d, n;
cin >> y >> m >> d >> n;
int array_m[] = {31,28,31,30,31,30,31,31,30,31,30,31};
for(int i = 0; i < m-1; i++)
{
n += array_m[i];
}
if(((y % 4 == 0) && (y % 100 != 0)) || (y % 400 == 0))
{
n += 1;
}
cout << y << "-" << m << "-" << d << "是第" << n+d << "天" << endl;
return 0;
}