分支结构:一年中的第几天

文章介绍了如何使用if-else嵌套和switch语句在编程中处理日期问题,计算给定合法日期是当年的第几天,同时考虑了闰年的情况。通过示例展示了如何在C++中实现这个功能,包括闰年的特殊处理和输出格式的要求。
摘要由CSDN通过智能技术生成
任务描述

本关任务:输入一个日期,如“ 2017 6 15 ”,计算这一天是这一年的第几天(1月1日是第一天)并输出。假设输入的都是合法的日期,但别忘了考虑闰年的情况。

相关知识

if 语句回根据对某个条件的判断结果,将程序的流程分为两支。而本关将要介绍的是会将程序分为多个分支的语句:

  • if-else 嵌套

  • switch 语句

下面我们就一起来学习这两种语句的使用。

if-else 嵌套

多路分支的第一种实现方法就是使用 if-else 嵌套,即在 if 分支和(或者) else 分支中再嵌套 if-else 语句。

例如:

  1. cin >> angle; // 输入角度
  2. if (angle % 90 == 0)
  3. {
  4. // if-else嵌套
  5. if (angle % 180 == 0)
  6. cout << "线段在X轴上" << endl;
  7. else
  8. cout << "线段在Y轴上" << endl;
  9. }
  10. else
  11. cout << "线段在象限" << angle / 90 + 1 << endl;

该程序计算输入的角度 angle 落在哪个象限或者哪个轴上。当输入的角度是90的倍数时(angle % 90 == 0为真),有两种情况,或者在X轴上,或者在Y轴上,所以需要其它条件(angle % 180 == 0)再次判断进行区分处理。

上面程序通过 if-else 嵌套实现了三路分支。

switch 语句

另一种实现多路分支的方法是使用 switch 语句, 格式如下:

  1. switch(<条件表达式>)
  2. {
  3. case <常量表达式1>:
  4. <语句序列1>;
  5. case <常量表达式2>:
  6. <语句序列2>;
  7. ……
  8. case <常量表达式n>:
  9. <语句序列n>;
  10. default:
  11. <语句序列n+1>;
  12. }

其中,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 语句模式如下:

  1. switch(<条件表达式>)
  2. {
  3. case <常量表达式1>:
  4. <语句序列1>;
  5. break;
  6. case <常量表达式2>:
  7. <语句序列2>;
  8. break;
  9. ……
  10. case <常量表达式n>:
  11. <语句序列n>;
  12. break;
  13. default:
  14. <语句序列n+1>;
  15. }

其执行过程为:首先计算<条件表达式>,将得到的整型值与<常量表达式1>……<常量表达式n>的值逐个进行比较,一旦检测到与其中一个相等,则执行该常量表达式下的语句序列,执行完后,紧接着就执行 break 语句,离开该 switch 结构,不再执行后续分支的处理语句序列,转向执行整个 switch 语句的后继语句。

例如下面的程序将百分制转换成十分制输出。如输入85,计算 scorePhrase 为8,则执行 switch 语句后进入case 8:分支,输出‘B’,然后执行 break ;语句跳出整个 switch 语句:

  1. cin >> score; // 输入百分制分数
  2. scorePhrase = score / 10; // 计算分数段,转换成十分制
  3. // 判断并输出等级
  4. switch (scorePhrase)
  5. {
  6. case 10:
  7. case 9:
  8. cout << 'A' << endl;
  9. break;
  10. case 8:
  11. cout << 'B' << endl;
  12. break;
  13. case 7:
  14. cout << 'C' << endl;
  15. break;
  16. case 6:
  17. cout << 'D' << endl;
  18. break;
  19. case 0: case 1: case 2: case 3: case 4: case 5:
  20. cout << 'E' << endl;
  21. break;
  22. default:
  23. cout << "The score is illegal!" << endl;
  24. }
编程要求

在右侧编辑器中的Begin-End之间补充代码,通过输入的日期(数据由平台提供,以“年 月 日”的形式表示,需要你获取后使用)来判断该天是当年的第几天的要求。具体要求如下:

  1. 对于输入一个日期(年月日之间以一个空格间隔),形如2017 6 15,计算这一天是这一年的第几天并输出;

  2. 输出形式为“年-月-日是第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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌入式Dora

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值