博客
关于我
C++switch语句 | 判断某年某月有几天
阅读量:131 次
发布时间:2019-02-27

本文共 1804 字,大约阅读时间需要 6 分钟。

C++多分支选择结构

switch语句是多分支选择语句,用来实现多分支选择结构,switcht的一般形式如下,和C语言基本上一样,只是输出语句不同。

switch(表达式){     case 常量表达式1:语句1  case 常量表达式2:语句2  ……  case 常量表达式n:语句n  default:语句n+1}

switch后面的括号里的表达式,原则上允许为任何类型,多个case可以共用一组执行语句。

当swtich表达式的值与大括号里面的某一个case子句中的变量表达式的值相同时,就会执行此case子句后面的语句。

当所有的case子句中的常量表达式的值没有一个和switch表达式的值相同时,会执行default子句后面的语句。

switch后面大括号里面的每一个case表达式的值必须不同,否则就会出现相互矛盾。

大括号里面的case和default出现的次序不影响执行结果,也就是读者就算把default放到第一行也可以。

执行完一个case子句后,流程控制会转移到下一个case子句继续执行,case常量表达式只是起到语句标号作用,并不是在该处进行条件判断。

在执行switch语句时,根据表达式的值找到与之匹配的case子句后,就从这个case子句开始执行了,不再进行判断。

如果需要使流程跳出switch语句,可以用break语句。

案例:判断某年是否使闰年,并且判断这年的某月有几天。

#include 
using namespace std;int main(){ int year, month, mon; cout << "输入年份和月份,年月之间用空格隔开" << endl; cin >> year >> month; if (month < 1 || month>12) { cout << "输入的月份不存在" << endl; } else { if ((year % 4 == 0 && year % 100 != 0) || year % 100 == 0) { mon = 1; cout <
<< "年是闰年" << endl; } else { mon = 2; cout <
<< "年是平年" << endl; } } switch (month) { case 1:cout << "你输入的1月有31天"; break; case 2: if (mon==1) { cout << "你输入的2月有29天"; } else { cout << "你输入的2月有28天"; }; break; case 3:cout << "你输入的3月有31天" << endl; break; case 4:cout << "你输入的4月有30天" << endl; break; case 5:cout << "你输入的5月有31天" << endl; break; case 6:cout << "你输入的6月有30天" << endl; break; case 7:cout << "你输入的7月有31天" << endl; break; case 8:cout << "你输入的8月有31天" << endl; break; case 9:cout << "你输入的9月份有30天" << endl; break; case 10:cout << "你输入的10月有31天" << endl; break; case 11:cout << "你输入的11月有30天" << endl; break; case 12:cout << "你输入的12月有31天" << endl; break; default:cout << "输入有误!" << endl; break; }}

执行本程序之后

输入年份和月份,年月之间用空格隔开
2020 10
2020年是闰年
你输入的10月有31天

更多案例可以go公众号:C语言入门到精通

转载地址:http://qdfb.baihongyu.com/

你可能感兴趣的文章
mysql-connector-java各种版本下载地址
查看>>
mysql-EXPLAIN
查看>>
mysql-group_concat
查看>>
MySQL-redo日志
查看>>
MySQL-【1】配置
查看>>
MySQL-【4】基本操作
查看>>
Mysql-丢失更新
查看>>
Mysql-事务阻塞
查看>>
Mysql-存储引擎
查看>>
mysql-开启慢查询&所有操作记录日志
查看>>
MySQL-数据目录
查看>>
MySQL-数据页的结构
查看>>
MySQL-架构篇
查看>>
MySQL-索引的分类(聚簇索引、二级索引、联合索引)
查看>>
Mysql-触发器及创建触发器失败原因
查看>>
MySQL-连接
查看>>
mysql-递归查询(二)
查看>>
MySQL5.1安装
查看>>
mysql5.5和5.6版本间的坑
查看>>
mysql5.5最简安装教程
查看>>