内容简介:输入日期,如2018年11月07日,输出对应的星期数代码如下:执行结果如下:
输入日期,如2018年11月07日,输出对应的星期数代码如下:
// 历史上的某一天是星期几?未来的某一天是星期几? // 关于这个问题,最著名的计算公式是蔡勒(Zeller)公式。即w=y+[y/4]+[c/4]-2c+[26(m+1)/10]+d-1 // output: w: 0 - 周日; // 1 - 周一; // 2 - 周二; // 3 - 周三; // 4 - 周四; // 5 - 周五; // 6 - 周六; // 公式中的符号含义如下,w:星期; // c:世纪-1; // y:年(两位数); // m:月(m大于等于3,小于等于14,即在蔡勒公式中,某年的1、2月要看作上一年的13、14月来计算,比如2003年1月1日要看作2002年的13月1日来计算) // d:日; // []代表取整,即只要整数部分 // 注:C是世纪数减一,y是年份后两位,M是月份,d是日数。1月和2月要按上一年的13月和14月来算,这时C和y均按上一年取值 package main import ( "fmt" ) var weekday = [7]string{"周日", "周一", "周二", "周三", "周四", "周五", "周六"} func main() { var a, b, c uint16 = 2018, 11, 07 fmt.Printf("%d年%d月%d日是:%s\n", a, b, c, ZellerFunction2Week(a, b, c)) } func ZellerFunction2Week(year, month, day uint16) string { var y, m, c uint16 if month >= 3 { m = month y = year % 100 c = year / 100 } else { m = month + 12 y = (year - 1) % 100 c = (year - 1) / 100 } week := y + (y / 4) + (c / 4) - 2*c + ((26 * (m + 1)) / 10) + day - 1 if week < 0 { week = 7 - (-week)%7 } else { week = week % 7 } which_week := int(week) return weekday[which_week] }
执行结果如下:
1541555635(1).jpg
以上所述就是小编给大家介绍的《根据输入的日期(年月日)判断是星期几——golang实现》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深入理解C#(第3版)
斯基特 (Jon Skeet) / 姚琪琳 / 人民邮电出版社 / 2014-4-1 / 99.00元
本书是世界顶级技术专家“十年磨一剑”的经典之作,在C#和.NET领域享有盛誉。与其他泛泛介绍C#的书籍不同,本书深度探究C#的特性,并结合技术发展,引领读者深入C#的时空。作者从语言设计的动机出发,介绍支持这些特性的核心概念。作者将新的语言特性放在C#语言发展的背景之上,用极富实际意义的示例,向读者展示编写代码和设计解决方案的最佳方式。同时作者将多年的C#开发经验与读者分享,读者可咀其精华、免走弯......一起来看看 《深入理解C#(第3版)》 这本书的介绍吧!