C++ 判断闰年 & 洛谷习题P5737题解

哈喽大家好,我是余同学。最近看到了一道洛谷上用函数判断闰年的题目,和大家分享一下

判断闰年

判断闰年的条件:

  • 1、能被400整除
  • 2、能被100整除但不能被4整除

根据以上条件,我们就可以写一个最基本的判断闰年的程序了
代码如下:

#include <bits/stdc++.h>
using namespace std;

int main()
{
    
    
	int year;
	cin>>year;
	if(year%100==0)
	{
    
    
		if(year%400==0){
    
    
			cout<<"闰年"; 
		}else{
    
    
			cout<<"平年";
		}
	}
	else{
    
    
		if(year%4==0){
    
    
			cout<<"闰年"; 
		}
		else{
    
    
			cout<<"平年";
		}
	}
	return 0;
}

test1
话说Win11天天更新干嘛,现在成了这种字体

【深基7.例3】闰年展示

题目描述

输入 x , y x,y x,y,输出 [ x , y ] [x,y] [x,y] 区间中闰年个数,并在下一行输出所有闰年年份数字,使用空格隔开。

输入格式

输入两个正整数 x , y x,y x,y,以空格隔开。

输出格式

第一行输出一个正整数,表示 [ x , y ] [x,y] [x,y] 区间中闰年个数。

第二行输出若干个正整数,按照年份单调递增的顺序输出所有闰年年份数字。

样例输入 #1

1989 2001

样例输出 #1

3
1992 1996 2000

提示

数据保证, 1582 ≤ x < y ≤ 3000 1582\le x < y \le 3000 1582x<y3000

代码实现

这道题是洛谷上函数与结构体题单里的,所以我们使用函数来编写这个程序 ,当然,不用函数也不会错

定义输入不解释

#include <bits/stdc++.h>
using namespace std;
int x,y,cnt=0,a[2005]; //cnt表示闰年的数量,数组a存储闰年的年份
int main ()
{
    
    
	cin>>x>>y; //输入开始和结束年份
    return 0;
}

然后,创建cmp函数,它有一个参数year,表示当前年份。如果函数的返回值为1,则该年为闰年;反之,返回值为0,则为平年

并且,由于cmp函数只可能有两个返回值(truefalse,也就是10),所以该函数类型为bool

bool cmp(int year){
    
    
	if(year%400==0){
    
     //满足条件1
		return 1;
	}else if(year%100!=0&&year%4==0){
    
     //满足条件2
		return 1;
	}else{
    
     
		/*
		如果都不满足,则为平年,这个 else 也可以不写
		因为如果前面两个 if 语句都没有执行(也就是条件没满足),自然会执行这个 return 0 语句
		*/
		return 0;
	}
}

接下来,for循环,找出在范围内所有的闰年

for(int i=x;i<=y;i++){
    
     //从x开始,到y结束
	if(cmp(i)==1){
    
    
		cnt++;
		a[cnt]=i;
	}
	/*
	知识大科普:
	if(cmp(i)==1) 的等值语句:if(cmp(i)) 
	在if语句内部,cnt要先加 1,然后数组a存入当前年份,这种思路还有另一种写法
	a[++cnt]=i;
	它的功能也是先将cnt加上1,数组再更新
	*/
}

最后,输出所有信息

cout<<cnt<<endl;
for(int j=1;j<=cnt;j++){
    
    
	cout<<a[j]<<" ";
}

全部代码如下:

#include <bits/stdc++.h>
using namespace std;
bool cmp(int year){
    
    
	if(year%400==0){
    
    
		return 1;
	}else if(year%100!=0&&year%4==0){
    
    
		return 1;
	}else{
    
    
		return 0;
	}
}
int a[2000],x,y,cnt=0;
int main ()
{
    
    
	cin>>x>>y;
	for(int i=x;i<=y;i++){
    
    
		if(cmp(i)==1){
    
    
			cnt++;
			a[cnt]=i;
		}
	}
	cout<<cnt<<endl;
	for(int j=1;j<=cnt;j++){
    
    
		cout<<a[j]<<" ";
	}
    return 0;
}

test

猜你喜欢

转载自blog.csdn.net/weixin_45122104/article/details/126161223