第几天--acm.njupt
来源:互联网 发布:安卓游戏数据备份 编辑:程序博客网 时间:2024/06/09 17:24
/*在我们现在使用的日历中, 闰年被定义为能被4整除的年份,但是能被100整除而不能被400整除的年是例外,它们不是闰年。例如:1700, 1800, 1900 和 2100 不是闰年,而 1600, 2000 和 2400是闰年。
给定公元2000年1月1日后的某年某月某日(包括2000年1月1日),你的任务:(1)给出这一天从公元2000年1月1日开始逝去的天数,(2)判断这一天是当年的第几天。
输入
输入包含若干行,每行包含三个空格间隔的正整数,它们分别表示年、月、日。输入最后一行是−1, 不必处理。可以假设结果的年份不会超过9999。
输出
多组,每组两行,分别为每行输入所代表的一天从公元2000年1月1日开始逝去的天数、在当年的第几天。
样例输入
2000 1 1
2009 3 14
-1
样例输出
0
1
3360
73*/
#include<stdio.h>
int M[12] = {31,28,31,30,31,30,31,31,30,31,30,31};
int isRuinian(int year)
{
if (year % 100 == 0)
{
if (year % 400 == 0)
return 1;
else
return 0;
}
else
{
if (year % 4 == 0)
return 1;
else
return 0;
}
}
int countdate(int y,int m,int d)
{
int dates = 0;
int i;
for (i = 2000;i < y;i++)
{
if (isRuinian(i))
dates += 366;
else
dates += 365;
}
for (i = 0;i < m-1;i++)
dates += M[i];
dates += d-1;
if (isRuinian(y) && m>=2)
dates++;
return dates;
}
int thisyeardate(int y,int m,int d)
{
int i,dates=0;
for (i = 0;i < m-1;i++)
dates += M[i];
dates += d;
if (isRuinian(y) && m>=2)
dates++;
return dates;
}
int main()
{
int year,month,date;
while (scanf ("%d",&year)!=EOF && year != -1 )
{
scanf ("%d%d",&month,&date);
printf ("%d\n",countdate(year,month,date));
printf ("%d\n",thisyeardate(year,month,date));
}
return 0;
给定公元2000年1月1日后的某年某月某日(包括2000年1月1日),你的任务:(1)给出这一天从公元2000年1月1日开始逝去的天数,(2)判断这一天是当年的第几天。
输入
输入包含若干行,每行包含三个空格间隔的正整数,它们分别表示年、月、日。输入最后一行是−1, 不必处理。可以假设结果的年份不会超过9999。
输出
多组,每组两行,分别为每行输入所代表的一天从公元2000年1月1日开始逝去的天数、在当年的第几天。
样例输入
2000 1 1
2009 3 14
-1
样例输出
0
1
3360
73*/
#include<stdio.h>
int M[12] = {31,28,31,30,31,30,31,31,30,31,30,31};
int isRuinian(int year)
{
if (year % 100 == 0)
{
if (year % 400 == 0)
return 1;
else
return 0;
}
else
{
if (year % 4 == 0)
return 1;
else
return 0;
}
}
int countdate(int y,int m,int d)
{
int dates = 0;
int i;
for (i = 2000;i < y;i++)
{
if (isRuinian(i))
dates += 366;
else
dates += 365;
}
for (i = 0;i < m-1;i++)
dates += M[i];
dates += d-1;
if (isRuinian(y) && m>=2)
dates++;
return dates;
}
int thisyeardate(int y,int m,int d)
{
int i,dates=0;
for (i = 0;i < m-1;i++)
dates += M[i];
dates += d;
if (isRuinian(y) && m>=2)
dates++;
return dates;
}
int main()
{
int year,month,date;
while (scanf ("%d",&year)!=EOF && year != -1 )
{
scanf ("%d%d",&month,&date);
printf ("%d\n",countdate(year,month,date));
printf ("%d\n",thisyeardate(year,month,date));
}
return 0;
}
来源:http://acm.njupt.edu.cn/acmhome/problemdetail.do?&method=showdetail&id=1008
0 0
- 第几天--acm.njupt
- acm.njupt--1983
- acm.njupt--2026
- acm.njupt--1859
- acm.njupt--2027
- acm.njupt--2008
- acm.njupt--1882
- NJUPT ACM 合法日期
- 字符串排序--acm.njupt
- ACM——第几天
- HDU ACM 2005 第几天?
- ACM测试-L - 第几天?
- 杭电ACM 2005 第几天?
- 杭电ACM 2005: 第几天?
- 杭电 acm 2005(第几天?)
- 杭电acm P2005第几天
- acm.njupt 1001-1026 简单题
- 数的计算——acm.njupt
- 创业公司如何实施敏捷开发
- 字符串排序--acm.njupt
- STM32 硬件流控制含义 GPIO引脚配置
- ubuntu 迅雷(xware desktop)
- 强制转化为float类型
- 第几天--acm.njupt
- 左右滑动日历控件
- 因小失大
- h264解码器原理
- swift 面向对象
- 有关Java list 去重 保持当前排序的原生方法
- ASP.NET中使用CSS样式
- 制作openstack SPICE高性能Windows镜像
- php获取客户端真实IP 防止代理和作弊