一. 应用背景

今天在求非水平地面条件下短波辐射所需要的太阳天顶角,其中有一个参数是DAY:公历1月1日算起该天所在的天数。
因此得写一个算法来实现这个参数的求解。

二. 参考文献

《闰年算法为什么不能被100整除》
《计算某年某月某日是这一年的第几天》
《Python实现switch/case语句》

三. 代码

## 函数:几月几日是今年第几天
def cal_day(str1,str2,str3):  #输入年月日year=int(str1); mon=int(str2); day=int(str3) #将字符串转换为int型sumday=0 #初始化总天数month_1=[31,28,31,30,31,30,31,31,30,31,30,31]  #平年12个月的天数month_2=[31,29,31,30,31,30,31,31,30,31,30,31]  #闰年12个月的天数if (year%4==0 and year%100!=0 or year%400==0): #如果为闰年for i in range(mon-1):  #从年初到上一个月天数都是满的sumday=sumday+month_2[i] #加上闰年每个月天数sumday=sumday+day #加上本月的天数else:  #平年的情况for i in range(mon-1):sumday=sumday+month_1[i]sumday=sumday+dayreturn sumday #返回总天数print("1980年11月28日是第{}天".format(cal_day(1980, 11, 28)))

运行结果如下:

四. 注意事项

在写的过程中遇到了两个主要问题:

  1. 闰年的算法为什么会出现“能被4整除但不可以被100整除”,这跟天文学上的历法是有关系的。(斜体字引用自第一篇参考文献)
    首先我们要知道,年的概念,是地球围绕太阳一周的时间(所谓公转周期)称为一年,这个周期是相当稳定的,很长时间也不会变动1秒,但是很遗憾的是这个周期并不能被一天的时间整除,真正的一年其实是365.2423天(目前)。
    所以,如果每年定义为365天的话,1年就会多出0.2423天,4年就会多出0.9692天,非常接近1天,这样闰年就出现了,也就是每4年要有1年设置为366天,来抵消这多出的1天。规则为:
    ·1)如果年份能被4整除,则该年计为闰年;
    可是,假如不做调整的话,当400年的时候,累计才多出96.92天,闰年的设置却多出来100天,所以要在400年内,再撤销3个闰年。怎么撤销呢?就有了下面这个规则:
    ·2)如果年份能被100整除,则不计为闰年;
    问题又来了,400年里有4个,又少了一个,所以再加一个规则就是:
    ·3)如果年份能被400整除,则计为闰年。
    这样每400年里设置了97个闰年,误差被调整到400年仅有0.08天,而设置规则也并不是很麻烦,所以一直沿用了下来。

  2. python3.10以下没有switch-case语句,我所使用的是3.8,因此在我复制switch语句时,会出现如下的报错,说我是无效的语法:

    所以我就想着用for循环遍历一遍,反正也只有闰年和平年两种情况

下一步就继续求短波辐射了

【简单算法】计算几月几日是一年的第几天相关推荐

  1. 8月30日云栖精选夜读:Nodejs进阶:使用DiffieHellman密钥交换算法

    原文地址 Diffie-Hellman(简称DH)是密钥交换算法之一,它的作用是保证通信双方在非安全的信道中安全地交换密钥.目前DH最重要的应用场景之一,就是在HTTPS的握手阶段,客户端.服务端利用 ...

  2. 6月29日云栖精选夜读:Java、PHP、Python、JS 等开发者都如何绘制统计图

    原文链接 目前很多程序员绘图基本上都是采用后端生成数据传递给前端,然后前端将数据渲染到绘图库上面进行显示,从而得到我们最后看到的各种图,但是有时候,我们发现需要传递的数据很多很多,那么这个时候如果将数 ...

  3. 2月09日云栖精选夜读:2018CCTV网络春晚:胡晓明携阿里云ET城市大脑给大家拜早年啦!...

    2月8日晚,在2018CCTV网络春晚上,阿里云总裁胡晓明带着同样是"保平安"的ET城市大脑给全国观众拜年啦! ET城市大脑是什么 ET城市大脑是整个城市的人工智能中枢,可以对整个 ...

  4. 直播预告|5月25日14:00 AAAI 专场二

    点击蓝字 关注我们 AI TIME欢迎每一位AI爱好者的加入! 5月25日14:00,本期我们邀请到AAAI的八位学者给大家带来精彩的分享! 5月25日 14:00-14:30 刘方鑫: 上海交通大学 ...

  5. 3月6日云栖精选夜读:如何实现32.5万笔/秒的交易峰值?阿里交易系统TMF2.0技术揭秘...

    交易平台遇到的挑战 2017双11,交易峰值达到了32.5万笔/秒,这给整个交易系统带来了非常大的挑战. 一方面,系统需要支撑全集团几十个事业部的所有交易类需求:要考虑如何能更快响应需求.加快发布周期 ...

  6. 6月26日云栖精选夜读:成为一名Java高级工程师你需要学什么

    摘要: 1.技术广度方面 至少要精通多门开源技术吧,研究过框架等的源码. 2.项目经验方面 从头到尾跟过几个大项目,头是指需求阶段,包括需求调研. 尾是指上线交付之后,包括维护阶段. 1.技术广度方面 ...

  7. NPC位置及各种商业技能上限(150225)突破方法 5月25日修订 附图

    <!-- --> <html> <head> <meta http-equiv='Content-Type' content="text/html; ...

  8. AI开发者大会之计算机视觉技术实践与应用:2020年7月3日《RPA+AI助力政企实现智能时代的人机协同》、《5G风口到来,边缘计算引领数据中心变革》、《数字化时代金融市场与AI算法如何结合?》

    AI开发者大会之计算机视觉技术实践与应用:2020年7月3日<RPA+AI助力政企实现智能时代的人机协同>.<5G风口到来,边缘计算引领数据中心变革>.<数字化时代金融市 ...

  9. 03【C语言 趣味算法】(值得品味的一道题)打鱼还是晒网?结构体的简单应用。函数的应用。判断闰年的应用。求指定日期距1990年1月1日的天数。

    目录 一.指路哦 三.打鱼还是晒网 嘞? 3.1 问题描述 3.2 问题分析 3.3 算法设计 3.4 确定程序框架 3.5 求出指定日期距 1990年1月1日的天数 3.6 完整code 及结果 一 ...

最新文章

  1. 牛顿迭代法求解平方根
  2. OpenStack Neutron运行机制解析概要
  3. 需求分析中应该注意的问题
  4. Frida-跨平台注入工具基础篇
  5. 深度学习maxout单元
  6. 跟一个傻逼程序员合作是什么感受?
  7. 字节流转化为文件流_字节流转成字符串之后,在通过字符串转成字节流后的文件为什么会不一样?...
  8. mysql 语句检查_mysql查询语句
  9. python中dtype什么意思_什么是dtype('O')?
  10. 一张图学会python3语法-一张图理清 Python3 所有知识点
  11. 数据库的点数据根据行政区shp来进行行政区处理,python定时器实现
  12. 唐宇迪学习笔记11:决策树算法
  13. windows系统c语言编译器安装
  14. java程序员面试题大全含答案(2018--2019)
  15. [打印管理器]读取样式列表失败:Invalid variant operation
  16. 手机、PDA、车载GPS导航入门手册
  17. 21. 合并两个有序链表 C语言
  18. C++控制台五子棋(带背景音乐)
  19. python画双y轴图像
  20. Android 百度地图 SDK v3.0.0 (四) 引入离线地图功能

热门文章

  1. photoshop序列号问题
  2. ARM M3综合细节描述:
  3. 和WiFi共享精灵一起成长
  4. 微信小程序之字体样式设置
  5. 帧同步,帧同步是什么意思
  6. 数独问题每行每列每3X3
  7. 阿里 卫哲谈阿里人力招聘价值观
  8. 物联网智慧物流平台开发
  9. 字节跳动面试锦集(二):项目HR高频面试总结
  10. 谈谈对springioc的理解