问题描述:
中国有句俗语叫“三天打鱼两天晒网”。某人从2010年1月1日起开始“三天打鱼两天晒网”,问这个人在以后的某一天中是“打鱼“还是’晒网’。用C或C ++语言/ JAVA /Python实现程序解决问题。
问题分析与算法设计:
根据题意可以将解题过程分为三步:
1)计算从2010年1月1日开始至指定日期共有多少天;
2)由于“打鱼”和“晒网”的周期为5天,所以将计算出的天数用5去除;
3)根据余数判断他是在“打鱼”还是在“晒网”;
若余数为1,2,3,则他是在“打鱼”
若余数为0,4 ,是在“晒网”
代码如下:
package cn.itcast;
/**
* @author 李丹
*/
import java.io.FileWriter;
import java.io.IOException;
import java.util.Scanner;
public class HomeWork {
public static void main(String[] args) throws IOException
{
Scanner s = new Scanner(System.in);
System.out.println("请输入年,月,日:");
int y =s.nextInt();
int m =s.nextInt();
int d =s.nextInt();
if(y>=2010&&m<=12&&d<=31) {
FileWriter writer =new FileWriter("in.txt.txt",true);
writer.write(y+"-"+m+"-"+d);
writer.write("\r\n");
writer.close();
int s0=0;//记录相差的天数
int s1=0;//记录这一年已经过去的天数
switch(m-1)
{
case 11:s1+=30;
case 10:s1+=31;
case 9: s1+=30;
case 8: s1+=31;
case 7: s1+=31;
case 6: s1+=30;
case 5: s1+=31;
case 4: s1+=30;
case 3: s1+=31;
case 2: if(y%4==0&&y%100!=0||y%400==0)
s1+=29;
else s1+=28;
case 1: s1+=31;
}
s1+=d;
if(y==2010)
{
s0=s1-1;
}else if(y>2010)
{
int s2=364;//计算2010年1月1日这一年还剩下多少天 (2010年为平年365天)
int s3=0;//统计相差的年份的整天数闰年366非闰年365
for(int i=2011;i<y;i++)
{
if(i%4==0&&i%100!=0||i%400==0) {
s3+=366;
}else {
s3+=365;
}
}
s0=s1+s2+s3;
}
System.out.println(y+"-"+m+"-"+d+"与2010-1-1相差"+s0+"天");
if(s0%5==0||s0%5==1||s0%5==2)
{
System.out.println(y+"年"+m+"月"+d+"日在打渔");
FileWriter writer1=new FileWriter("out.txt.txt",true);
writer1.write(y+"-"+m+"-"+d+"在打渔");
writer1.write("\r\n");
writer1.close();
}else {
System.out.println(y+"年"+m+"月"+d+"日在晒网");
FileWriter writer2 =new FileWriter("out.txt.txt",true);
writer2.write(y+"-"+m+"-"+d+"在晒网");
writer2.write("\r\n");
writer2.close();
}
}else {
System.out.println("输入日期有误,请输入合理日期");
}
}
}
程序流程图:
调试结果: