
上一篇学习了分支结构,想着编程是解决问题的核心,就希望寻找一个用分支嵌套分支来解决问题的实例。
对于地理老师来说不难,判断公历年份是不是闰年就是一个可以用分支嵌套分支来解决的问题。对于不少人来说,公历的闰年规则似乎是“四年一闰”,其实闰年规则不是“四年一闰”,而是“四百年九十七闰”!
如果“四年一闰”,四百年就应该是一百闰,但实际上四百年只有九十七闰,比一百个闰年少了三个闰年。这个闰年的规则因此就变得复杂了一点,细分成了两个分规则:
如果年份数能被100整除的,必须是400的倍数,才是闰年;如果年份数不能被100整除的,必须是4的倍数,才是闰年。
这样的两个分规则结合起来,正好保证四百年里有九十七个闰年。
我们将这个规则,用流程图表示出来:

这个流程图看得清楚吗?我们再将这个流程图转化成python程序代码:
【尝试】
i=int(input("输入一个年份"))
if i % 100 == 0:
if i % 400 == 0:
print(i,"是闰年")
else:
print(i,"是平年")
else:
if i % 4 == 0:
print(i,"是闰年")
else:
print(i,"是平年")
运行程序。输入:1900,输出:1900 年是平年;输入:2000,输出:2000 年是闰年;输入:1984,输出:1984 年是闰年;输入:1977,输出:1977 年是平年
如果我们不用分支嵌套来编写代码,而是用多路分支+逻辑运算来编写代码,能不能解决闰年判断这个问题呢?能被100整除 并且能被400整除的年份数是闰年;不能被100整除,并且能被4整除的年份数是闰年;其余,都是平年。
【尝试】
i=int(input("输入一个年份"))
if i % 100 == 0 and i % 400 == 0:
print(i,"年是闰年")
elif i % 100 != 0 and i % 4 == 0:
print(i,"年是闰年")
else:
print(i,"年是平年")
运行程序。完全可以进行正确判断。