热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

语句练习4(打印万年历)

计算任何一天是星期几的几种算法:一:常用公式W[Y-1]+[(Y-1)4]-[(Y-1)100]+[(Y-1)400]+DY是年份数,D是这一

计算任何一天是星期几的几种算法:

 

一:常用公式 

  W = [Y-1] + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D

 

  Y是年份数,D是这一天在这一年中的累积天数,也就是这一天在这一年中是第几天。

 

二:蔡勒(Zeller)公式

 

   w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1

 

  公式中的符号含义如下,w:星期;c:世纪;y:年(两位数); m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算);d:日;[ ]代表取整,即只要整数部分。

 

   相比于通用通用计算公式而言,蔡勒(Zeller)公式大大降低了计算的复杂度。

 

 三:对蔡勒(Zeller)公式的改进

 

作者:冯思琮 
  相比于另外一个通用通用计算公式而言,蔡勒(Zeller)公式大大降低了计算的复杂度。不过,笔者给出的通用计算公式似乎更加简洁(包括运算过程)。现将公式列于其下: 
W=[y/4]+r (y/7)-2r(c/4)+m’+d

 

公式中的符号含义如下,r ( )代表取余,即只要余数部分;m’是m的修正数,现给出1至12月的修正数1’至12’如下:(1’,10’)=6;(2’,3’,11’)=2;(4’,7’)=5;5’=0;6’=3;8’=1;(9’,12’)=4(注意:在笔者给出的公式中,y为润年时1’=5;2’=1)。其他符号与蔡勒(Zeller)公式中的含义相同。

 

四:基姆拉尔森计算公式

 

 这个公式名称是我给命名的,哈哈希望大家不要见怪。

 

W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7

 

  在公式中d表示日期中的日数,m表示月份数,y表示年数。

 

 1         //W = [Y-1] + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D
 2         //Y:代表年份   D:表示上个月31号在这一年中的累积天数
 3         int year;//用来存放输入的年份
 4         int month;//用来存放输入的月份
 5         int days=0;//用来存放月份中的天数
 6         int zdays=0;//用来存放输入的这一天距离1900.1.1的天数差
 7         int week;//存放 这个月的1号是星期几
 8         boolean isRn;//判断是否是闰年后返回真假值
 9         System.out.println("☆☆☆☆☆☆☆☆☆☆欢迎使用万年历☆☆☆☆☆☆☆☆☆");
10         Scanner scan=new Scanner(System.in);  
11         System.out.print("请输入年份:");
12         year=scan.nextInt();
13         System.out.print("请输入月份:");
14         mOnth=scan.nextInt();
15         //首先判断输入的年份是平年还是闰年 
16         if(year%400==0||(year%4==0&&year%100!=0)){
17             isRn=true;
18             System.out.print(year+"年是闰年!");
19         }
20         else{
21             isRn=false;
22             System.out.print(year+"年是平年!");
23         }
24         //加上到上个月的31号的天数
25         for(int j=1;j<=month;j++){
26             switch(j){
27                case 1:
28                case 3: 
29                case 5:
30                case 7:
31                case 8:
32                case 10:
33                case 12:
34                    days=31;
35                    break;
36                case 4:
37                case 6:
38                case 9:
39                case 11:
40                    days=30;
41                    break;
42                case 2:
43                    if(isRn) {days=29;}
44                    else {days=28;}
45                    break;
46                 default:
47                     System.out.println("你输入的月份有误!");
48             }
49             if(j<month){
50                 zdays+=days;
51             }
52         }
53         
54         System.out.println(month+"月有"+days+"天。");
55         //计算 这个月的1号是星期几
56         week=(year-1)+(year-1)/4-(year-1)/100+(year-1)/400+zdays;
57         week=1+week%7;
58         if(week==7) { week=0;}//如果是7 则表示星期日  前边0个制表符
59         System.out.println("日\t一\t二\t三\t四\t五\t六\n");
60         for(int i=0;i){
61             System.out.print("\t");
62         }
63         for(int i=1;i<=days;i++){
64             System.out.print(i+"\t");
65             if((i+week)%7==0){//打印到7个数字 换行
66                 System.out.println();
67             }
68         }

 

运行结果:

         

 


推荐阅读
  • switch语句的一些用法及注意事项
    本文介绍了使用switch语句时的一些用法和注意事项,包括如何实现"fall through"、default语句的作用、在case语句中定义变量时可能出现的问题以及解决方法。同时也提到了C#严格控制switch分支不允许贯穿的规定。通过本文的介绍,读者可以更好地理解和使用switch语句。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • 提升Python编程效率的十点建议
    本文介绍了提升Python编程效率的十点建议,包括不使用分号、选择合适的代码编辑器、遵循Python代码规范等。这些建议可以帮助开发者节省时间,提高编程效率。同时,还提供了相关参考链接供读者深入学习。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了brain的意思、读音、翻译、用法、发音、词组、同反义词等内容,以及脑新东方在线英语词典的相关信息。还包括了brain的词汇搭配、形容词和名词的用法,以及与brain相关的短语和词组。此外,还介绍了与brain相关的医学术语和智囊团等相关内容。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • C语言注释工具及快捷键,删除C语言注释工具的实现思路
    本文介绍了C语言中注释的两种方式以及注释的作用,提供了删除C语言注释的工具实现思路,并分享了C语言中注释的快捷键操作方法。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
author-avatar
手机用户2602930645
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有