在页面上输出1900年以后任意一年的简易日历表

package text3;

import java.util.Scanner;

public class MyCalendar {
  public static void main(String[] args){
    String Weeks = " Su Mo Tu We Th Fr Sa "; //星期列表
    int i,j; //循环控制变量
    System.out.println("Please input the year you want to research:");
    int year = new Scanner(System.in).nextInt();
    //用于计算所给定年份1月1日为星期几,初值为1900年的1.1为周一
    int Ospa3 = 1;
    //从1900年开始,计算其后每一年的1.1为周几,直到求出指定年份的1.1日
    for(i = 1;i < year;i++){
      //若是闰年,其后年份的1.1日加两天,否则加一天
      if(i % 4 == 0 && i % 100 != 0 || i % 400 == 0)
        Ospa3 += 2;
      else
        Ospa3++;
    }
    //由于七天为一周,所以Ospa3的最终值应为模7的余数
    Ospa3 %= 7;
    //输出日历第一行提示信息
    System.out.println("\t\t\tCalender of " + year);
    //输出星期列表,每行显示三个星期
    i = 1;
    while(i <= 3){
      System.out.print(Weeks);
      i++;
    }
    System.out.println("");
    //存放连续三个月的1日对应的星期和当月的总天数
    int spa1 = 0,spa2 = 0,spa3 = 0,cou1 = 0,cou2 = 0,cou3 = 0;
    //存放连续三个月的当前日期
    int day1 = 0,day2 = 0,day3 = 0;
    //判断当年是否为闰年,计算二月份的天数
    boolean leap = year %4 ==0 && year % 100 != 0 || year % 400 == 0;
    for(j = 1;j <= 28;j++){ //????为什么是28
      if((j-1)%7 == 0){
      day1 = 1;
      day2 = 1;
      day3 = 1; //设置连续3个月的日期输出均从1号开始
      //分别设置一年中每个月1日的星期,和当月的总天数
      switch(j/7){
      case 0:
        spa1 = Ospa3;
        cou1 = 31; //1月
        spa2 = (spa1 + cou1) % 7;
        cou2 = leap ?29:28; //2月
        spa3 = (spa2 + cou2) % 7;
        cou3 = 31; //3月
        Ospa3 = spa3;
        break;
      case 1:
        spa1 = (Ospa3 + cou3) % 7;
        cou1 = 30; //4月
        spa2 = (spa1 + cou1) % 7;
        cou2 = 31; //5月
        spa3 = (spa2 + cou2) % 7;
        cou3 = 30; //6月
        Ospa3 = spa3;
        break;
      case 2:
        spa1 = (Ospa3 + cou3) % 7;
        cou1 = 31; //7月
        spa2 = (spa1 + cou1) % 7;
        cou2 = 31; //8月
        spa3 = (spa2 + cou2) % 7;
        cou3 = 30; //9月
        Ospa3 = spa3;
        break;
      case 3:
        spa1 = (Ospa3 + cou3) % 7;
        cou1 = 31; //10月
        spa2 = (spa1 + cou1) % 7;
        cou2 = 30; //11月
        spa3 = (spa2 + cou2) % 7;
        cou3 = 31; //12月
        break;

      }

    }
    //在屏幕上输出日历,一行显示3个星期共输出21列
    for(i = 1;i <= 21; i++){
      if ((i-1)/7 == 0) //每一行的前七列输出第一个月
        System.out.print(spa1--<=0 && day1 <= cou1? day1 < 10?" 0"+
        day1++ :" " + day1++ :" ");
      else if((i - 1)/7 == 1)
        System.out.print(spa2--<=0 && day2 <= cou2? day2 < 10?" 0"+
        day2++ :" " + day2++ :" ");
      else
        System.out.print(spa3--<=0 && day3 <= cou3? day3 < 10?" 0"+
        day3++ :" " + day3++ :" ");
      if(i % 7 == 0)
        System.out.print(" ");//每行中月份之间的空格
    }
    System.out.println(" "); //换行
    }
  }
}

java 简易日历表的更多相关文章

  1. java简易编辑器

    package peng_jun; import java.awt.*; import java.awt.event.*; import javax.swing.*; import javax.swi ...

  2. 数据结构——单链表java简易实现

    巩固数据结构 单链表java实现 单链表除了表尾 每个几点都有一个后继 结点有数据和后继指针组成  通过构建表头和表尾(尾部追加需要)两个特殊几点 实现单链表的一些操作,代码如下 package co ...

  3. 补码一位乘法 Booth算法 Java简易实现

    本文链接:https://www.cnblogs.com/xiaohu12138/p/11955619.html. 转载,请说明出处. 本程序为简易实现补码一位乘法,若代码中存在错误,可指出,本人会不 ...

  4. Java简易日历的实现

    import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; imp ...

  5. mongo数据管理java简易版

    mongo是搭建在局域网服务器上的,处理起来比较麻烦,于是自己写了个简单的处理工具. 如果有对java操作mongo不太了解的也可以在这里看下简单的示例. 只有增删改查的功能,而且只支持json格式的 ...

  6. 纯Java——简易高并发框架

    转自:https://blog.csdn.net/MonkeyDCoding/article/details/81369610 0.源代码github-简易高并发框架 注:本篇博客知识来自于网课. 1 ...

  7. java简易excel导入导出工具(封装POI)

    Octopus 如何导入excel 如何导出excel github项目地址 Octopus Octopus 是一个简单的java excel导入导出工具. 如何导入excel 下面是一个excel文 ...

  8. java简易DVD影片管理系统—面向对象

    public class DvdSet { String name [] =new String[15]; // DVD电影名称 String date [] =new String[15]; //D ...

  9. Java打印日历表

    今天来吐槽一下Java的Calendar类的使用问题,反正我是弄了半天. 首先是,遇到一个问题,输入年份和月份,需要打印这个月的日历,网上有不少代码,但我用了几个感觉都不是很靠谱. 然后经过一番探索, ...

随机推荐

  1. Xamarin 自定义OnKeyDown 再按一次退出程序的实现

    private DateTime? lastBackKeyDownTime; public override bool OnKeyDown(Keycode keyCode, KeyEvent e) { ...

  2. Codeforces 526C.Om Nom and Candies

    题目描述 一个只有两个物品的背包问题,但是范围都是1e9,需要考虑根号或者log的复杂度. 如果这两个物品中的某一个花费超过了根号C,那么我们可以直接枚举这件物品的数量,另一件物品的数量可以计算得出. ...

  3. Pollard-Rho算法求大数质因子

    /* * 大整数分解到现在都是世界级的难题,但却是一个重要的研究方向,大整数在公共密钥的研究上有着重要的作用 * Pollard Rho算法的原理就是通过某种方法得到两个整数a和b.而待分解的大整数为 ...

  4. git-中文乱码

    Windows系统的Git默认是不支持中文显示的,需要进行一系列的设置才能避免乱码的出现,下面总结如何配置Git使其支持中文显示. Git bash options UTF-8编码配置 1.首先进入g ...

  5. 前后端通信—CORS(支持跨域)

    根据前端跨域的那些事这篇文章中的跨域的理解这一块,我们重新创建两个服务,第一个服务使用了test.html const http = require('http') const fs = requir ...

  6. SSH框架整合2

    ===========================================web.xml================================================== ...

  7. 集合类 collection接口 ArrayList

    数组: 存储同一种数据类型的集合容器.数组的特点:1. 只能存储同一种数据类型的数据.2. 一旦初始化,长度固定. 3. 数组中的元素与元素之间的内存地址是连续的. : Object类型的数组可以存储 ...

  8. IntelliJ IDEA Check out from git

    点击check out from vesion control 填写git地址,test,clone

  9. Comparator中返回0导致数据丢失的大坑

    今天对一列数据进行排序,因为存储的是Map结构,要实现排序,马上就想到了TreeMap,于是查到API,这样新建TreeMap就能实现添加的时候就自动排序. new TreeMap<>(n ...

  10. mac安装MySQLdb:IndexError: string index out of range

    使用mac安装MySQLdb的时候出现string index out of range 大概的错误是这样的: 然后尝试手动安装,我下载了包后,依然出现这个错误. 于是百度了下: https://ww ...