在页面上输出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. [RN] React Native 使用 React-native-scrollable-tab-view 实现 类头条 新闻页头部 效果

    React Native 使用 React-native-scrollable-tab-view 实现 类头条 新闻页效果 效果如下: 一.安装依赖 npm install react-native- ...

  2. CF1237C2 【Balanced Removals (Harder)】

    这么妙的题怎么没人发题解啊 首先这是三维的,我们可以对其进行降维打击 先考虑一维怎么做? 我们可以对其该维坐标进行排序,按照顺序输出,可能会多余一个 那拓展到二维呢? 我们可以把它转化成一维,分成很多 ...

  3. 【loj2262】【CTSC2017】网络

    题目 一颗\(n\)个点的树,求加入一条边点之后两点间最长距离的最小值 : \(n \le 100000\) ; 题解 首先加入边的两个端点一定在直径上面,先\(dfs\)拎出直径来讨论(下标只代表直 ...

  4. Codeforces & Atcoder神仙题做题记录

    鉴于Codeforces和atcoder上有很多神题,即使发呆了一整节数学课也是肝不出来,所以就记录一下. AGC033B LRUD Game 只要横坐标或者纵坐标超出范围就可以,所以我们只用看其中一 ...

  5. Cocos Creator打包发布

    若本号内容有做得不到位的地方(比如:涉及版权或其他问题),请及时联系我们进行整改即可,会在第一时间进行处理. 请点赞!因为你们的赞同/鼓励是我写作的最大动力! 欢迎关注达叔小生的简书! 这是一个有质量 ...

  6. SSM项目实战 之 Maven

    目录 Maven 简介 Maven是什么 Maven下载安装 Maven使用 Maven规定了一套默认的项目格式 创建第一个Maven项目 Maven仓库 Maven常用命令 Maven作用范围(sc ...

  7. Thinking In SE

    各种编程范式的区别 并发模型 并行架构: 位级(bit-level)并行 指令级(instruction-level)并行 数据级(data)并行 数据级并行 任务级(task-level)并行 -- ...

  8. CEF拦截js层alert弹窗 OnJSDialog 《转》

    一 引言 CEF3嵌入后,用JS 弹出Alert框,按钮错位,确定按钮勉强能看到.很难看.为了改善体验,决定重写提示框. 环境:VS2008  VC  MFC.   二 原理 参看类 CefJSDia ...

  9. linux 的 两种磁盘扩容

    当LVM分区空间不足的时候,可以进行扩容.主要的扩容方法有两种: 通过空余的磁盘进行扩容,这个方法比较简单,不会对原有数据有影响.将其他LVM分区空间取出一部分给需要扩容的LVM分区.下面就分别具体介 ...

  10. PyCharm虚拟环(Project Interpreter)手动安装第三方包图解教程

    PyCharm虚拟环(Project Interpreter)手动安装第三方包图解教程 an鑫_wolfxin2010 关注 2018.03.13 21:58* 字数 313 阅读 3782评论 1喜 ...