中国有句俗语叫“三天打鱼两天晒网”。某人从2010年1月1日起开始“三天打鱼两天晒网”,问这个人在以后的某一天中是“打鱼”还是“晒网”。
步骤:
1.算法分析根据题意可以将解题过程分为三步:
1)计算从2010年1月1日与指定日期相差多少天;
2)由于“打鱼”和“晒网”的周期为5天,所以将计算出的天数用5去除;
3)根据余数判断他是在“打鱼”还是在“晒网”;
若 余数为0,1,2,则他是在“打鱼”
否则 是在“晒网”
求从2010年1月1日与指定日期相差多少天,要判断经历年份中是否有闰年,二月为29天,平年为28天。闰年的方法可以用伪语句描述如下:
如果 ((年能被4除尽 且 不能被100除尽)或 能被400除尽)
则 该年是闰年;
否则 不是闰年。
2.概要设计
可多次判断日期;
判断输入年份是否合法;
判断输入的月份是否合法;
判断输入的日期是否合法;
判断是否退出;
判断打鱼还是晒网;
判断是否是闰年;
计算距离输入日期多少天;
计算2010-(year-1)之间有多少天;
计算本年内该日期之前共有多少天;
判断每月有几天;
计算本年内该日期之前共有多少天。
流程图
3.测试
4.调试
5.心得体会
在进行本题的设计过程中,我又重新复习了一遍Java语言的相关语法,除了基本的循环结构还有数据处理。本题中最核心的部分莫过于计算指定日期到2010年1月1日的总天数这一个环节了,在考虑了多个算法之后,最终选定了源代码中呈现的算法。这个过程也学习到了很多。
import java.util.Scanner;
public class work{
public static void main(String[] args) {
boolean a = true;//变量a用于判断退出
//可多次判断日期
while(a){
Scanner scanner = new Scanner(System.in);
System.out.println("请输入年份:");
int year = scanner.nextInt();
//判断输入年份是否合法
while(year<2009)
{
System.out.println("您输入的年份太早啦!");
System.out.println("请再次输入年份:");
year