Java实现简单的万年历
作者:&小小白& 发布时间:2023-11-29 08:31:24
标签:java,万年历
本文实例为大家分享了Java实现简单万年历的具体代码,供大家参考,具体内容如下
1 要求
1、输入年份;
2、输入月份;
3、输出某年某月的日历。
2 思路
1、实现从控制台接收年和月,判断是否是闰年(判断是否是闰年:能被4整除但不能被100整除;或者能被400整除);
2、计算输入月份的天数;
3、计算该月第一天是星期几;
3.1 计算输入年份距离1900年1月1日的天数;
3.2 计算输入月份之前的天数(从当年年初开始);
3.3 将以上两组数据进行求和;
3.4 已知该月之前的天数,计算输入月份的第一天是星期几(从1900年1月1日(星期一)开始推算: 星期几 = 1 + 天数差 % 7 )。
4、按格式输出该月日历 。
3 源代码
import java.util.Scanner;
public class index {
//每个月的天数
public static int monthday(int month, int year) {
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
int[] day = {0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
return day[month];
} else {
int[] day = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
return day[month];
}
}
//月份总天数
public static int monthdays(int month, int year) {
int totaldays = 0;
for (int i = 1; i < month; i++) {
totaldays = totaldays + monthday(i, year);
}
return totaldays;
}
//距离1900年的年份总天数
public static int yeardays(int year){
int yeardays = 0;
for (int i = 1900;i<year;i++){
if ((i % 4 == 0 && i % 100 != 0) || i % 400 == 0) {
yeardays = yeardays+366;
} else {
yeardays = yeardays+365;
}
}
System.out.println(year+"年距离1900年的总天数"+yeardays);
return yeardays;
}
//输出日历
public static void printCalendar(int month,int year){
int totaldays = 0;
if (year > 0) {
if (month > 0 && month < 13) {
//距离1900年1月1日总天数
totaldays = monthdays(month,year)+yeardays(year);
System.out.println(year+"年"+month+"月1日距离1900年的总天数:"+totaldays);
System.out.println("\n**********"+year+"年"+month+"月的日历为**********");
System.out.println("一\t二\t三\t四\t五\t六\t日\t");
int week = 1+totaldays%7;
//根据1日为周几输出空格
for(int i=1;i<week;i++){
System.out.print(" \t");
}
//输入具体日期
for(int i=1;i<=monthday(month,year);i++){
System.out.print(i+"\t");
if(week==7){
week = 1;//重置为星期一
System.out.println();
}else{
week++;
}
}
} else {
System.out.println("输入的月份不合法!");
}
} else {
System.out.println("输入的年份不合法!");
}
}
//主函数
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("***********************欢迎使用万年历**************************");
System.out.println("*********请选择你需要进行的操作(输入进行操作之前的数字)**********");
System.out.println("********************1.查询某年某月的日历************************");
System.out.println("********************2.结束操作*********************************");
System.out.print("\n请选择你需要进行的操作:");
int a = scanner.nextInt();
for (int i=0;i>=0;i++) {
switch (a) {
case 1:
System.out.print("请选择年份:");
int year = scanner.nextInt();
System.out.print("请选择月份:");
int month = scanner.nextInt();
printCalendar(month, year);
System.out.print("\n请选择你需要进行的操作:");
a = scanner.nextInt();
break;
case 2:
System.out.println("退出程序成功!");
return;
}
}
}
}
4 结果截图
注意:我的周日是在最后一栏
来源:https://blog.csdn.net/qq_52916408/article/details/115820910
0
投稿
猜你喜欢
- 本文实例讲述了C#模拟Http与Https请求框架类。分享给大家供大家参考。具体实现方法如下:using System.Text;using
- 实现代码一、import java.io.File;import java.io.*;public class DelNullDir {pu
- 概述从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章.链表链表 (Linked List) 是一种递归的动态数
- SpringMVC一般使用MultipartFile来做文件的上传,通过MultipartFile的getContentType()方法判定
- boot-admin整合Quartz实现动态管理定时任务淄博烧烤爆红出了圈,当你坐在八大局的烧烤摊,面前是火炉、烤串、小饼和蘸料,音乐响起,
- 本文实例讲述了C#访问SqlServer设置链接超时的方法。分享给大家供大家参考。具体实现方法如下:下面这段代码设置超时时间为60秒,默认为
- 什么是分布式锁?在回答这个问题之前,我们先回答一下什么是锁。普通的锁,即在单机多线程环境下,当多个线程需要访问同一个变量或代码片段时,被访问
- 场景:简单工厂时候,我设计了一个场景,有三种剑去打怪,这时候,需求变化了,我三种剑变成了,匕首、剑以及木棒,想要用工厂方法来实现,怎么弄?1
- 本文实例分析了Android中GridView和ArrayAdapter用法。分享给大家供大家参考,具体如下:GridView是一个表格化的
- 前言Set 表示由无重复对象组成的集合,也是集合框架中重要的一种集合类型,直接扩展自 Collection 接口。在一个 Set 中,不能有
- 开发设计搞了一个带圆形进度的进度条,在GitHub上逛了一圈,发现没有,自己撸吧。先看界面效果:主要思路是写一个继承ProgressBar的
- 最近在做一个 Android 项目,需要用到GPS获取位置信息,从 API 查了一下,发现获取位置信息仅需极其简单的一句即可:getLast
- 本文实例为大家分享了C#简单爬虫案例,供大家参考,具体内容如下using System;using System.Collections.G
- 目录前言错误实例演示实现ApplicationContextAware接口lookup methodlookup method签名总结前言看
- Android MediaPlayer实现音乐播放器1、布局文件<?xml version="1.0" encod
- 为了提升编译速度,这几天用上了 AS 3.0 和 Gradle 3.0 插件,不得不说不论是 AS 3.0,还是 Gradle 3.0 都变
- 1.面对对象的初步认识1.1什么是面向对象用面向对象的思想来涉及程序,更符合人们对事物的认知,对于大型程序的设计、扩展以及维护都非常友好。1
- 一、效果图:二、导入 jar 包1.由于这是大神写好封装起来的一个框架,所有我们使用前得先下载相关的 jar 包第一种:maven<!
- 1. 前言Compose 具有超强的兼容性,兼容现有的所有代码,Compose 能够与现有 View 体系并存,可实现渐进式替换。这就很有意
- 递归生成一个如图的菜单,编写两个类数据模型Menu、和创建树形的MenuTree。通过以下过程实现:1.首先从菜单数据中获取所有根节点。2.