蓝桥杯备赛1-2合法日期

题目描述

小蓝正在上小学,老师要求同学们在暑假每天记日记。可是小蓝整个暑假都在玩,直到最后一天才想起要记日记。于是小蓝赶紧编了一些日记交给老师。

没想到,日记很快就被老师发现了问题,原来小蓝记完 8 月 31 日的日记,竟又记了 8 月 32 日和 8 月 33 日的日记。这显然是有问题的,因为根本没有 8 月 32 日和 8 月 33 日。

给定一个月份和一个日期,请问 2021 年有没有这一天。

输入描述

输入的第一行包含一个整数 mm,表示月份。

第二行包含一个整数 dd,表示日期。

其中,1≤m≤20,1≤d≤401≤m≤20,1≤d≤40。

输出描述

如果2021年有 mm 月 dd 日,输入 yes,否则输出 no

输入输出样例

示例 1

输入

复制代码
8
32

输出

复制代码
no
示例 2

输入

复制代码
2
28

输出

复制代码
yes

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 128M

题解1

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
  // 请在此输入您的代码
  int m,n;
  cin>>m>>n;
  if(m==2)
  {
    if(n<=28){
      cout<<"yes";
    }else{
      cout<<"no";
    }
  }
  else if(m==1||m==3||m==5||m==7||m==8||m==10||m==12)
  //在 C++ 中,表达式 m==1||3||5||7||8||10||12 并不是按你预期的方式工作的。这个表达式实际上会被解释为 (m==1) || (3) || (5) || (7) || (8) || (10) || (12),其中非零整数(如 3、5、7 等)在布尔上下文中被视为 true。因此,只要 m 不等于 1,这个条件就会被视为 true,这不是你想要的行为。
  {
    if(n<=31){
      cout<<"yes";
    }else{
      cout<<"no";
    }
  }
  else if(m==3||m==4||m==6||m==9||m==11)
  {
    if(n<=30){
      cout<<"yes";
    }else{
      cout<<"no";
    }
  }else//忽略了m的范围
  {
    cout<<"no";
  }
  return 0;
}

题解2

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
  int month[31]={0,31,28,31,30,31,30,31,31,30,31,30,31};
  int m,d;
  cin>>m>>d;
  if(month[m]<d)
  cout<<"no";
  else cout<<"yes";
  return 0;
}
相关推荐
csdn_aspnet1 天前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
谙弆悕博士1 天前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
gaosushexiangji1 天前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法
小王C语言1 天前
【线程概念与控制】:线程封装
jvm·c++·算法
kyle~1 天前
工程数学---点云配准卡布施(Kabsch)算法(求解最优旋转矩阵)
线性代数·算法·矩阵
张二娃同学1 天前
03_变量常量与输入输出_printf与scanf详解
算法
江南十四行1 天前
并发编程(一)
java·jvm·算法
z200509301 天前
今日算法(依旧二叉树)
算法·leetcode·职场和发展
Zxc_1 天前
《遗传算法:从自然选择到Rastrigin函数优化,手写一个完整的进化求解器》
算法
阿Y加油吧1 天前
两道经典动态规划题:乘积最大子数组 & 分割等和子集 复盘笔记
笔记·算法·动态规划