版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、利用日期、经纬度求日出日落时间 C语言程序代码#define PI 3.1415926 #include<math.h> #include<iostream> 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,3
2、0,31,30,31; long double h=-0.833; /定义全局变量 void input_date(int c) int i; cout<<"Enter the date (form: 2009 03 10):"<<endl;
3、; for(i=0;i<3;i+) cin>>ci; /输入日期 void input_glat(int c) int i;
4、60; cout<<"Enter the degree of latitude(range: 0°- 60°,form: 40 40 40 (means 40°4040):"<<endl; for(i=0;i<3;i+) &
5、#160;cin>>ci; /输入纬度 void input_glong(int c) int i; cout<<"Enter the degree of longitude(west is negativ,
6、form: 40 40 40 (means 40°4040):"<<endl; for(i=0;i<3;i+) cin>>ci; /输入经度 int leap_year(in
7、t year) if(year%400=0) | (year%100!=0) && (year%4=0) return 1; else return 0; /判断是否为闰年:若为闰年,返回1;若非闰年,返回0 int days(int year, int&
8、#160;month, int date) int i,a=0; for(i=2000;i<year;i+) if(leap_year(i) a=a+366; else
9、;a=a+365; if(leap_year(year) for(i=0;i<month-1;i+) a=a+days_of_month_2i;
10、 else for(i=0;i<month-1;i+) a=
11、a+days_of_month_1i; a=a+date; return a; /求从格林威治时间公元2000年1月1日到计算日天数days long double t_
12、century(int days, long double UTo) return (long double)days+UTo/360)/36525; /求格林威治时间公元2000年1月1日到计算日的世纪数t long double L_sun(long double t_century)
13、return (280.460+36000.770*t_century); /求太阳的平黄径 long double G_sun(long double t_century) return (357.528+35999.050*t_century); /求太阳的平近点角 long double ecliptic_longitude(lo
14、ng double L_sun,long double G_sun) return (L_sun+1.915*sin(G_sun*PI/180)+0.02*sin(2*G_sun*PI/180); /求黄道经度 long double earth_tilt(long double t_century) retur
15、n (23.4393-0.0130*t_century); /求地球倾角 long double sun_deviation(long double earth_tilt, long double ecliptic_longitude) return (180/PI*asin(sin(PI/180*earth_tilt)*sin(PI/180*ecliptic_longitude)
16、; /求太阳偏差 long double GHA(long double UTo, long double G_sun, long double ecliptic_longitude) return (UTo-180-1.915*sin(G_sun*PI/180)-0.02*sin(2*G_sun*PI/180)+2.466*sin(2*ecliptic_lon
17、gitude*PI/180)-0.053*sin(4*ecliptic_longitude*PI/180); /求格林威治时间的太阳时间角GHA long double e(long double h, long double glat, long double sun_deviation) return 180/PI*acos(sin(h*PI/1
18、80)-sin(glat*PI/180)*sin(sun_deviation*PI/180)/(cos(glat*PI/180)*cos(sun_deviation*PI/180); /求修正值e long double UT_rise(long double UTo, long double GHA, long double glong, long double e)
19、60; return (UTo-(GHA+glong+e); /求日出时间 long double UT_set(long double UTo, long double GHA, long double glong, long double e) return (UTo-(GHA+glo
20、ng-e); /求日落时间 long double result_rise(long double UT, long double UTo, long double glong, long double glat, int year, int month, int date) lon
21、g double d; if(UT>=UTo) d=UT-UTo; else d=UTo-UT; if(d>=0.1) UTo=UT; &
22、#160; 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_ce
23、ntury(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; /判断并返回
24、结果(日出) 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;
25、0; if(UT>=UTo) d=UT-UTo; else d=UTo-UT; if(d>=0.1) UTo=UT; UT=UT_set(UTo,
26、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
27、(t_century(days(year,month,date),UTo); result_set(UT,UTo,glong,glat,year,month,date); return UT; /判断并返回结果(日落) int Zone(long dou
28、ble 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
29、set, long double glong) if(int)(60*(rise/15+Zone(glong)-(int)(rise/15+Zone(glong)<10) cout<<"The time at which the sun rises is "<
30、;<(int)(rise/15+Zone(glong)<<":0"<<(int)(60*(rise/15+Zone(glong)-(int)(rise/15+Zone(glong)<<" .n" else cout<<"The time at which the sun rises is "<<(int
31、)(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) cout<&
32、lt;"The 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 cout<<"
33、;The time at which the sun sets is "<<(int)(set/15+Zone(glong)<<":"<<(int)(60*(set/15+Zone(glong)-(int)(set/15+Zone(glong)<<" .n" /打印结果
34、 int main() long double UTo=180.0; int year,month,date; long double glat,glong; int c3;
35、60; input_date(c); year=c0; month=c1; date=c2; input_glat(c); glat=c0+c1/60+c2/3600; input_glong(c);
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 制图纸产品供应链分析
- 电源控制器市场发展前景分析及供需格局研究预测报告
- 蓄电瓶市场分析及投资价值研究报告
- 电子测量设备项目运营指导方案
- 穿孔乐谱纸卷项目运营指导方案
- 办公机器和设备租用行业营销策略方案
- 药用次硝酸铋市场发展前景分析及供需格局研究预测报告
- 仿裘皮产业链招商引资的调研报告
- 头发造型器具出租行业营销策略方案
- 实验室用滴定管产业链招商引资的调研报告
- 江苏省镇江市第二中学2023-2024学年高二上学期期中考试数学试卷(无答案)
- 2023-2024学年全国初一下生物人教版期末考试试卷(含答案解析)
- 2024年甘肃省陇南市武都区人民法院招聘18人历年高频难、易错点500题模拟试题附带答案详解
- 2024-2030年中国虚拟专用网络(VPN)行业市场行业发展分析及发展前景研究报告
- 检验检测机构内审员检查表
- 2024中煤电力限公司面向中煤集团内部招聘15人高频难、易错点500题模拟试题附带答案详解
- 统编版(2024新版)七年级上册历史第二单元 夏商周时期:奴隶制王朝的更替和向封建社会的过渡 单元复习课件
- 安徽省江南十校2025届高一数学第一学期期末经典试题含解析
- 3.2 世界的地形(教学设计)七年级地理上册同步高效备课课件(人教版2024)
- 2024南京航空航天大学科学技术研究院招聘历年高频500题难、易错点模拟试题附带答案详解
- 2024上海烟草集团北京卷烟厂限公司招聘31人高频500题难、易错点模拟试题附带答案详解
评论
0/150
提交评论