package com.hr;

import java.util.Date;
import java.util.Scanner;

/**
 * 输入年、月、日
 * 输出到今天有多少天
 * 1.出生那一年到今年共有多少个闰年,多少个平年,
 * 2.如果是闰年乘以366,如果是平年乘以365.
 * 3.如果是月直接累加
 */
public class TestRiLi {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int year = 1900;
        int month = 1;
        int date = 1;
        //今天的
        Date now = new Date();
        System.out.println("请输入年:");
        //int yearNow = 2020;
        int yearNow = input.nextInt();
        System.out.println("请输入月:");
        //int monthNow = 11;
        int monthNow = input.nextInt();
        System.out.println("请输入日:");
        //int dateNow = 1;
        int dateNow = input.nextInt();
        //以下算出1900年1月1日到你输入的年月日有多少天,然后推出一月的第一天是星期几
        //1.年的天数
        int sum = 0;
        for (int i = year; i < yearNow; i++) {
            if (i % 4 == 0 && i % 100 != 0 || i % 400 == 0) {
                sum = sum + 366;
            } else {
                sum = sum + 365;
            }
        }
        //2.月的天数,因为是1月1日就不用减月的天数
        int after = 0;
        for (int i = 1; i < monthNow; i++) {
            if (i == 4 || i == 6 || i == 9 || i == 11) {
                after = after + 30;
            } else if (i == 2) {
                if (yearNow % 4 == 0 && yearNow % 100 != 0 || yearNow % 400 == 0) {
                    after = after + 29;
                } else {
                    after = after + 28;
                }
            } else {
                after = after + 31;
            }
        }
        //总天数
        int all = sum + after + 1;
        System.out.println(all); //44135  2020 11 1 此月第一天为星期日
        //3.由此我们可以推出每个月的第一天是星期几
        int start = all % 7;
        System.out.println("这个月的第一天是星期:" + start);
        //以下为输出的格式排版======================================
        //解决第一个月开始天数为7的问题
        if (start == 7) {
            start = 0;
        }
        //输出日历头
        System.out.println("日\t一\t二\t三\t四\t五\t六");
        //输出没有日期的部分,空白部分
        for (int i = 1; i <= start; i++) {
            System.out.print("\t");
        }
        //这里的31用上次做的求某年某个月的天数来做
        //从这个月第一天开始输出,要求每七个换一行
        for (int i = 1; i <= 31; i++) {
            System.out.print(i + "\t");
            //每七个换一行
            if ((i + start) % 7 == 0) {
                System.out.println();
            }
        }
    }
}

 

Logo

昇腾计算产业是基于昇腾系列(HUAWEI Ascend)处理器和基础软件构建的全栈 AI计算基础设施、行业应用及服务,https://devpress.csdn.net/organization/setting/general/146749包括昇腾系列处理器、系列硬件、CANN、AI计算框架、应用使能、开发工具链、管理运维工具、行业应用及服务等全产业链

更多推荐