/*
从键盘输入一个日期,格式为 yyyy-M-d
要求计算该日期与 1949 年 10 月 1 日距离多少天
例如:
用户输入了:1949-10-2
程序输出:1
用户输入了:1949-11-1
程序输出:31
*/
package Question20_29;
import java.util.Scanner;
public class Question24MustRemember {
public static int dayOfYear[]={365,366};//平年365天,闰年366天
public static int dayOfMonth[][]={
46
{0,31,28,31,30,31,30,31,31,30,31,30,31},
{0,31,29,31,30,31,30,31,31,30,31,30,31}
};
public static int dayOfYearIndex(int year){ //根据是否是闰年来给出dayOfYear的数组的下标
if((year%4==0&&year%100!=0)||year%400==0){
return 1;
}
return 0;
}
public static int dayApartFromTheBrginOfYear(int year,int month,int day){//计算month月day日是year年的第
几天
int days=day;
for (int i = 1; i < month; i++) {
days+=dayOfMonth[dayOfYearIndex(year)][i];
}
return days;
}
public static int apartDays(String startDayString,String endDayString ) {
String s1[]=startDayString.split("-");
String s2[]=endDayString.split("-");
int days=0;
int flag;
int startYear=Integer.parseInt(s1[0]);
int endYear=Integer.parseInt(s2[0]);
int startMonth=Integer.parseInt(s1[1]);
int endMonth=Integer.parseInt(s2[1]);
int startDay=Integer.parseInt(s1[2]);
int endDay=Integer.parseInt(s2[2]);
for (int i = startYear; i < endYear; i++) {
days+=dayOfYear[dayOfYearIndex(i)];
}
days+=dayApartFromTheBrginOfYear(endYear,endMonth,endDay);
days-=dayApartFromTheBrginOfYear(startYear,startMonth,startDay);
return days;
}
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
String startDayString="1949-10-01";
String endDayString=scanner.nextLine();
System.out.println(apartDays(startDayString, endDayString));
}
47
}

运行结果:

输入日期格式为:(1949-10-2)

输入第一个日期:1949-10-2

输入第二个日期:1949-11-2

1949-10-2 到 1949-11-2

距离 31 天

最新文章

  1. mysql cpu和内存监控
  2. Oracle数据库如何创建DATABASE LINK?
  3. System.load(PWConnector.dll)加载异常 Can&#39;t find dependent libraries
  4. 6、软件配置工程师要阅读的书籍 - IT软件人员书籍系列文章
  5. 数据库实现多站点共享Session
  6. 《深入浅出WPF》笔记二
  7. Chart 绘制,自带动画效果
  8. html dl dt dd标签元素语法结构与使用
  9. 学习总结 java线程
  10. 华为OJ—字符串排序(排序,忽略指定字符排序)
  11. SQL 的一些概念问答
  12. Android_TextVIew_flow_ex1
  13. PHP 递归创建目录
  14. The Viewport Transformation
  15. sqlite学习笔记4:表的创建和删除
  16. rsync+inotify实现实时同步案例【转】
  17. 关于tensorflow中tensorborad No dashboards are active for the current data set.的解决办法
  18. Jquery插件收集【m了慢慢学】
  19. 求其中同一个主叫号码的两次通话之间间隔大于10秒的通话记录ID
  20. hibernate 标签inverse cascade

热门文章

  1. 数据库中取出YYYY-mm-dd H:i:s的数据怎么将其转化成YYYY/mm/dd格式,另外,怎么将一个数据表中的数据插入另一个数据表
  2. call(),apply(),bind() 区别和用法
  3. vue v-for 渲染input 输入有问题 解决方案
  4. ScheduleMaster新特性之延时任务初体验
  5. linux常用命令---yum 工具
  6. linux常用命令---系统辅助命令
  7. zz 关于插入意向间隔锁( insert intention gap lock)产生的死锁问题
  8. Java集合--阻塞队列及各种实现的解析
  9. 【python爬虫】scrapy实战1--百万微博任性采集
  10. mysql 赋权语句