很简单的一道题,在博主看来要比 CSP 201412-2 Z字形扫描 要简单得多,主要就是闰年的判断以及月份天数的判断,用天数按顺序减去相应月份的天数,剩下的天数不够一个月了,就是日期数
一、题目
1.问题描述
给定一个年份y和一个整数d,问这一年的第d天是几月几日?
注意闰年的2月有29天。满足下面条件之一的是闰年:
1) 年份是4的整数倍,而且不是100的整数倍;
2) 年份是400的整数倍。
2.输入格式
输入的第一行包含一个整数y,表示年份,年份在1900到2015之间(包含1900和2015)。
输入的第二行包含一个整数d,d在1至365之间。
3.输出格式
输出两行,每行一个整数,分别表示答案的月份和日期。
4.样例输入/书橱
样例输入
2015
80
样例输出
3
21
样例输入
2000
40
样例输出
2
9
二、解题思路
这道题没有太难,解题思路在文章开头就说过了,在这里就不赘述了
好吧,还是在说一下吧:
利用循环,挨个减去月份的天数,直到剩余天数<月的天数,即可退出循环,此时的月份就是日期的月,剩余天数就是日期的日
我们所需要做的就是把月和天数联系在一起
在c中,我们可以使用if语句,而在python中,我们有更好的东西——字典
博主为了偷懒,用了python,需要c的同学,看了博主的解题思路也应该会了(不会了可以留言,但大概率懒惰的博主会回复,但找一个其他博主的文章推给你)
三、代码
year=int(input())
a={}
for i in range(13):
if i==1 or i==3 or i==5 or i==7 or i==8 or i==10 or i==12:
a[i]=31
if i==4 or i==6 or i==9 or i==11:
a[i]=30
if i==2:
if year%4==0 and year%100!=0 or year%400==0:
a[i]=29
else:
a[i]=28
day=int(input())
for i in a.keys():
if day>a[i]:
day-=a[i]
q=i
else:
break
print(i)
print(day)
四、运行结果
总结
没啥总结的,和博主一起念阿弥陀佛,保佑我考试这么简单
bybe~