java实现输入日期
2024-10-09 05:26:31
/*
从键盘输入一个日期,格式为 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 天
最新文章
- mysql cpu和内存监控
- Oracle数据库如何创建DATABASE LINK?
- System.load(PWConnector.dll)加载异常 Can&#39;t find dependent libraries
- 6、软件配置工程师要阅读的书籍 - IT软件人员书籍系列文章
- 数据库实现多站点共享Session
- 《深入浅出WPF》笔记二
- Chart 绘制,自带动画效果
- html dl dt dd标签元素语法结构与使用
- 学习总结 java线程
- 华为OJ—字符串排序(排序,忽略指定字符排序)
- SQL 的一些概念问答
- Android_TextVIew_flow_ex1
- PHP 递归创建目录
- The Viewport Transformation
- sqlite学习笔记4:表的创建和删除
- rsync+inotify实现实时同步案例【转】
- 关于tensorflow中tensorborad No dashboards are active for the current data set.的解决办法
- Jquery插件收集【m了慢慢学】
- 求其中同一个主叫号码的两次通话之间间隔大于10秒的通话记录ID
- hibernate 标签inverse cascade
热门文章
- 数据库中取出YYYY-mm-dd H:i:s的数据怎么将其转化成YYYY/mm/dd格式,另外,怎么将一个数据表中的数据插入另一个数据表
- call(),apply(),bind() 区别和用法
- vue v-for 渲染input 输入有问题 解决方案
- ScheduleMaster新特性之延时任务初体验
- linux常用命令---yum 工具
- linux常用命令---系统辅助命令
- zz 关于插入意向间隔锁( insert intention gap lock)产生的死锁问题
- Java集合--阻塞队列及各种实现的解析
- 【python爬虫】scrapy实战1--百万微博任性采集
- mysql 赋权语句