算法练习题01:月份天数

【问题描述】

输入年份和月份,输出该年该月共有多少天(需要考虑闰年)

【输入格式】

输入两个整数year和month,表示年和月。

【输出格式】

一个整数,表示该年该月的天数。

【输入样例1】

1926 8

【输出样例1】

31

【输入样例2】

2000 2

【输出样例2】

29

我的答案:烂

复制代码
#include<stdio.h>
int main(){
	int y;
	int m;
	int a1 = 29;
	int a2 = 28;
	int a3 = 30;
	int a4 = 31; 
	scanf("%d",&y);
	scanf("%d",&m);
	switch(m){
		case 1:{
			printf("%d",a4);
			break;
		}
		case 2:{
			if(y%4==0&&y%100!=0||y%400==0){
				printf("%d",a1);
			}
			else{
				printf("%d",a2);
			}
			break;
		}
		case 3:{
			printf("%d",a4);
			break;
		}
		case 4:{
			printf("%d",a3);
			break;
		}
		case 5:{
			printf("%d",a4);
			break;
		}
		case 6:{
			printf("%d",a3);
			break;
		}
		case 7:{
			printf("%d",a4);
			break;
		}
		case 8:{
			printf("%d",a4);
			break;
		}
		case 9:{
			printf("%d",a3);
			break;
		}
		case 10:{
			printf("%d",a4);
			break;
		}
		case 11:{
			printf("%d",a3);
			break;
		}
		case 12:{
			printf("%d",a4);
			break;
		}
	}
} 

老师答案:

复制代码
#include<iostream>
using namespace std;

// 判断是否为闰年的函数
bool leap(int year) {
    return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0);
}

int main() {
    int feb, year, month;
    int day;

    cin >> year >> month;

    // 判断闰年,确定二月的天数
    if (leap(year)) {
        feb = 29;
    } else {
        feb = 28;
    }

    // 根据月份确定天数
    switch (month) {
        case 1: case 3: case 5: case 7: case 8: case 10: case 12:
            day = 31;
            break;
        case 4: case 6: case 9: case 11:
            day = 30;
            break;
        case 2:
            day = feb;
            break;
        default:
            cout << "Invalid month" << endl;
            return 1; // 返回非零值表示错误
    }

    cout << day << endl;
    return 0;
}
相关推荐
『昊纸』℃13 分钟前
C语言学习心得集合 篇1
c语言·算法·编程基础·学习心得·实践操作
Chase_______19 分钟前
LeetCode 1456:定长子串中元音的最大数目
算法·leetcode
小O的算法实验室20 分钟前
2026年IEEE IOTJ,DNA序列启发相似性驱动粒子群算法+无人机与基站部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
谭欣辰20 分钟前
Floyd算法:动态规划解最短路径
c++·算法·图论
计算机安禾20 分钟前
【Linux从入门到精通】第12篇:进程的前后台切换与信号控制
linux·运维·算法
6Hzlia23 分钟前
【Hot 100 刷题计划】 LeetCode 84. 柱状图中最大的矩形 | C++ 两次单调栈基础扫法
c++·算法·leetcode
C雨后彩虹32 分钟前
文件目录大小
java·数据结构·算法·华为·面试
0南城逆流035 分钟前
【技术点】嵌入式技术考点三:数据结构
java·数据结构·算法
罗湖老棍子35 分钟前
Beads(信息学奥赛一本通- P1461) [POI 2010] KOR-Beads(洛谷-P3498)
算法·字符串·哈希
paeamecium36 分钟前
【PAT甲级真题】- Favorite Color Stripe (30)
数据结构·c++·算法·pat