任务描述
本关任务:输入一个日期,如“ 2017 6 15 ”,计算这一天是这一年的第几天(1月1日是第一天)并输出。假设输入的都是合法的日期,但别忘了考虑闰年的情况。
相关知识
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;
}
编程要求
在右侧编辑器中的Begin-End
之间补充代码,通过输入的日期(数据由平台提供,以“年 月 日”的形式表示,需要你获取后使用)来判断该天是当年的第几天的要求。具体要求如下:
-
对于输入一个日期(年月日之间以一个空格间隔),形如
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;
// 请在此添加代码,计算并输出指定日期是第几天
/********** Begin *********/
scanf("%d %d %d", &y, &m, &d);
if (((y % 4) == 0 && (y % 100) != 0) || (y % 400 == 0))
{
switch(m)
{
case 1:
n = d;
break;
case 2:
n = 31 + d;
break;
case 3:
n = 60 + d;
break;
case 4:
n = 91 + d;
break;
case 5:
n = 121 + d;
break;
case 6:
n = 152 + d;
break;
case 7:
n = 182 + d;
break;
case 8:
n = 213 + d;
break;
case 9:
n = 244 + d;
break;
case 10:
n = 274 + d;
break;
case 11:
n = 305 + d;
break;
case 12:
n = 335 + d;
break;
}
}
else
{
switch(m)
{
case 1:
n = d;
break;
case 2:
n = 31 + d;
break;
case 3:
n = 59 + d;
break;
case 4:
n = 90 + d;
break;
case 5:
n = 120 + d;
break;
case 6:
n = 151 + d;
break;
case 7:
n = 181 + d;
break;
case 8:
n = 212 + d;
break;
case 9:
n = 243 + d;
case 10:
n = 273 + d;
break;
case 11:
n = 304 + d;
break;
case 12:
n = 334 + d;
break;
}
}
/********** End **********/
printf("%d-%d-%d是第%d天\n",y,m,d,n);
return 0;
}