




已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/日出日落时间计算C语言程序#define PI 3.1415926 #include #include using namespace std; int days_of_month_1=31,28,31,30,31,30,31,31,30,31,30,31; int days_of_month_2=31,29,31,30,31,30,31,31,30,31,30,31; long double h=-0.833; /定义全局变量 void input_date(int c) int i; coutEnter the date (form: 2009 03 10):endl; for(i=0;ici; /输入日期 void input_glat(int c) int i; coutEnter the degree of latitude(range: 0- 60,form: 40 40 40 (means 404040):endl; for(i=0;ici; /输入纬度 void input_glong(int c) int i; coutEnter the degree of longitude(west is negativ,form: 40 40 40 (means 404040):endl; for(i=0;ici; /输入经度 int leap_year(int year) if(year%400=0) | (year%100!=0) & (year%4=0) return 1; else return 0; /判断是否为闰年:若为闰年,返回1;若非闰年,返回0 int days(int year, int month, int date) int i,a=0; for(i=2000;iyear;i+) if(leap_year(i) a=a+366; else a=a+365; if(leap_year(year) for(i=0;imonth-1;i+) a=a+days_of_month_2i; else for(i=0;i=UTo) d=UT-UTo; else d=UTo-UT; if(d=0.1) UTo=UT; UT=UT_rise(UTo,GHA(UTo,G_sun(t_century(days(year,month,date),UTo),ecliptic_longitude(L_sun(t_century(days(year,month,date),UTo),G_sun(t_century(days(year,month,date),UTo),glong,e(h,glat,sun_deviation(earth_tilt(t_century(days(year,month,date),UTo),ecliptic_longitude(L_sun(t_century(days(year,month,date),UTo),G_sun(t_century(days(year,month,date),UTo); result_rise(UT,UTo,glong,glat,year,month,date); return UT; /判断并返回结果(日出) long double result_set(long double UT, long double UTo, long double glong, long double glat, int year, int month, int date) long double d; if(UT=UTo) d=UT-UTo; else d=UTo-UT; if(d=0.1) UTo=UT; UT=UT_set(UTo,GHA(UTo,G_sun(t_century(days(year,month,date),UTo),ecliptic_longitude(L_sun(t_century(days(year,month,date),UTo),G_sun(t_century(days(year,month,date),UTo),glong,e(h,glat,sun_deviation(earth_tilt(t_century(days(year,month,date),UTo),ecliptic_longitude(L_sun(t_century(days(year,month,date),UTo),G_sun(t_century(days(year,month,date),UTo); result_set(UT,UTo,glong,glat,year,month,date); return UT; /判断并返回结果(日落) int Zone(long double glong) if(glong=0) return (int)(int)(glong/15.0)+1); else return (int)(int)(glong/15.0)-1); /求时区 void output(long double rise, long double set, long double glong) if(int)(60*(rise/15+Zone(glong)-(int)(rise/15+Zone(glong)10) coutThe time at which the sun rises is (int)(rise/15+Zone(glong):0(int)(60*(rise/15+Zone(glong)-(int)(rise/15+Zone(glong) .n; else coutThe time at which the sun rises is (int)(rise/15+Zone(glong):(int)(60*(rise/15+Zone(glong)-(int)(rise/15+Zone(glong) .n; if(int)(60*(set/15+Zone(glong)-(int)(set/15+Zone(glong)10) coutThe time at which the sun sets is (int)(set/15+Zone(glong): (int)(60*(set/15+Zone(glong)-(int)(set/15+Zone(glong) .n; else coutThe time at which the sun sets is (int)(set/15+Zone(glong):(int)(60*(set/15+Zone(glong)-(int)(set/15+Zone(glong) .n; /打印结果 int main() long double UTo=180.0; int year,month,date; long double glat,glong; int c3; input_date(c); year=c0; month=c1; date=c2; input_glat(c); glat=c0+c1/60+c2/3600; input_glong(c); glong=c0+c1/60+c2/3600; long double rise,set; rise=result_rise(UT_rise(UTo,GHA(UTo,G_sun(t_century(days(year,month,date),UTo),ecliptic_longitude(L_sun(t_century(days(year,month,date),UTo),G_sun(t_century(days(year,month,date),UTo),glong,e(h,glat,sun_deviation(earth_tilt(t_century(days(year,month,date),UTo),ecliptic_longitude(L_sun(t_century(days(year,month,date),UTo),G_sun(t_century(days(year,month,date),UTo),UTo,glong,glat,year,month,date); set=result_set(UT_set(UTo,GHA(UTo,G_sun(t_century(days(year,month,date),UTo),ecliptic_longitude(L_sun(t_century(days(year,month,date),UTo),G_sun(t_century(days(year,month,date),UTo),glong,e(h,glat,sun_deviation(earth_tilt(t_century(days(year,month,date)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 管道消防知识培训课件
- 大二班幼儿体格锻炼计划
- 2025年环境监测物联网在环境监测设备产业国际化进程中的技术应用报告
- 工程合同超额说明及处理规范
- 部编版道德与法治一年级教学目录
- 生意拆伙合同(标准版)
- 产品订做合同(标准版)
- 六年级毕业班主任致辞及典礼流程范文
- 冷链物流冷藏车技术改造方案
- 软件项目初验报告标准范本
- GB/T 528-2009硫化橡胶或热塑性橡胶拉伸应力应变性能的测定
- GB/T 4950-2021锌合金牺牲阳极
- 中日关系历史
- GB/T 15171-1994软包装件密封性能试验方法
- 2023年江苏省中学生生物学竞赛(奥赛)初赛试题和答案
- 信息系统运维服务方案
- 化工试生产总结报告
- 导数与原函数的对称性 微专题课件-2023届高三数学一轮复习
- DB32-T 3129-2016适合机械化作业的单体钢架塑料大棚 技术规范-(高清现行)
- 中西医结合肿瘤医院员工手册
- 健康教育学【完整版】
评论
0/150
提交评论