zoukankan      html  css  js  c++  java
  • java 实现打印当前月份的日历

    实现当前日历的打印,当前日期用*来表示。

    关键得出这个月的第一天是星期几。

    基姆拉尔森计算公式
    W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7  


    在公式中d表示日期中的日数+1,m表示月份数。y表示年数。
       
    注意1:在公式中有个与其它公式不同的地方:   
    把一月和二月看成是上一年的十三月和十四月,
    例:假设是2004-1-10则换算成:2003-13-10来代入公式计算。

    注意2:在大多数天主教国家的日历中,在1752年没有9.3-9.13。在这一年的日历中9月2号
    后面直接就是9月14号,所以在计算某天是星期几的算法中要把这一特殊情况考虑在内


    package work_0529;
    
    import java.util.Scanner;
    
    public class main {
    
    	private static int year;
    	private static int month;
    	private static int day;
    	private static boolean flag;
    	private static int count;//当前月份的天数
    	
    	public static void main(String[] args) {
    		
           
            	if(!getInput()) return; 
            	if(!judgeData()) return;
            	int a = getData();       	  
            	System.out.println("日   一   二   三   四   五   六");
            	int j=0;
            	while(a-- > 0){ System.out.print("    "); j++;}
            	for(int i=1;i <= count; i++)
            	{        		
            		if(j%7==0)System.out.println("
    ");
            		j++;
            		System.out.print(String.format("%4d",i));
            		if(day==i)System.out.print("*");
            	}
                
    	}
    
    	
    
    	private static boolean judgeData() {
    
    		flag=false;// false表示平年。反之
        	if(year%100==0) flag=true;
        	else if(year%4==0) flag=true;
        	if(year<=0){
        		System.out.println("年份不能小于等于0");
        		return false;
        	}
        	if(month<=0 || month>12){
    			System.out.println("检查月份的范围");
    			return false;
    		}
        	if(month==2){
        		if(flag && day>29){
        			System.out.println("当前为"+(flag?"闰年":"平年")+"二月份不能大于29");
        			return false;
        		}
        		if(!flag && day > 28){
        			System.out.println("当前为"+(flag?

    "闰年":"平年")+"二月份不能大于28"); return false; } if(flag) count=29; else count=28; } if(month==1 || month==3 || month==5|| month==7|| month==8|| month==10|| month==12) { if(day<=0 || day > 31){ System.out.println("检查日期的范围"); return false; } count =31; } else if(month!=2){ if(day<=0 || day>30){ System.out.println("检查日期的范围"); return false; } count = 30; } return true; } private static int getData() { int tmpDay=1;// 表示 int a; if (month == 1 || month == 2) { month += 12; year--; } if((year<1752) || (year==1752 && month<9) || (year==1752 && month==9 && tmpDay<3)){ a = (tmpDay + 2*month + 3*(month+1)/5 + year + year/4 +5) % 7; }else{ a = (tmpDay + 2*month + 3*(month+1)/5 + year + year/4 - year/100 + year/400)%7; } return a; } private static boolean getInput() { try { System.out.print("请输入日期(格式XXXX-XX-XX):"); Scanner scanner = new Scanner(System.in); String str = scanner.nextLine(); year = Integer.parseInt(str.substring(0, str.indexOf('-'))); str = str.substring(str.indexOf('-') + 1, str.length()); month = Integer.parseInt(str.substring(0, str.indexOf('-'))); str = str.substring(str.indexOf('-') + 1, str.length()); day = Integer.parseInt(str); return true; } catch (NumberFormatException e) { System.out.println("格式错误"); } catch (StringIndexOutOfBoundsException e2) { System.out.println("格式错误"); } return false; } }




  • 相关阅读:
    13-02 Java 数组高级算法,Arrays类
    从0移植uboot (二) _uboot启动流程分析
    Linux input子系统编程、分析与模板
    跟着内核学框架-从misc子系统到3+2+1设备识别驱动框架
    Linux驱动技术(八) _并发控制技术
    Linux驱动技术(七) _内核定时器与延迟工作
    Linux驱动技术(六) _内核中断
    Linux驱动技术(五) _设备阻塞/非阻塞读写
    Linux驱动技术(四) _异步通知技术
    Linux驱动技术(三) _DMA编程
  • 原文地址:https://www.cnblogs.com/brucemengbm/p/6821525.html
Copyright © 2011-2022 走看看