C语言编程 题目:模拟太阳升起。 要求:红太阳从地平线冉冉升起,直至屏幕右上角停止。 求高手解答

C语言编程 题目:模拟太阳升起。 要求:红太阳从地平线冉冉升起,直至屏幕右上角停止。 求高手解答,第1张

#include "graphics.h"

#include <stdio.h>

#include <conio.h>

#include <time.h>

void main()

{

int GD,GM

time_t t1,t2

int r,t,x0=159,y0=479

GD=DETECT

initgraph(&GD,&GM,"")

printf("请输入圆半径(10-50):\n")

scanf("%d",&r)

if(r<10 || r>50) r=30

printf("请输入变化间隔时间(秒):\n")

scanf("%d",&t)

setfillstyle(SOLID_FILL,WHITE)

bar(0,0,639,479)

x0=x0-r+5

y0=y0+r-5

setcolor(RED)

setfillstyle(SOLID_FILL,RED)

circle(x0,y0,r)

fillellipse(x0,y0, r,r)

t1=0

while(!kbhit()) //按键退出

{

t2=time(NULL)

if(t2-t1>t)

{

setcolor(WHITE)

circle(x0,y0,r-1)

circle(x0,y0,r)

circle(x0,y0,r+1)

setcolor(RED)

setfillstyle(SOLID_FILL,RED)

x0++

y0--

circle(x0,y0,r)

fillellipse(x0,y0, r,r)

t1=t2

}

if(x0+r>=639 || y0-r<=0) break

}

getch()//等待按键退出

closegraph()

}

#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,30,31,30,31} 

 long double h=-0.833 

 //定义全局变量 

void input_date(int c[]){ 

     int i 

     cout<<"Enter the date (form: 2009 03 10):"<<endl 

     for(i=0i<3i++){ 

         cin>>c[i] 

     } 

 } 

 //输入日期 

void input_glat(int c[]){ 

     int i 

     cout<<"Enter the degree of latitude(range: 0°- 60°,form: 40 40 40 (means 40°40′40″)):"<<endl 

     for(i=0i<3i++){ 

         cin>>c[i] 

     } 

 } 

 //输入纬度 

void input_glong(int c[]){ 

     int i 

     cout<<"Enter the degree of longitude(west is negativ,form: 40 40 40 (means 40°40′40″)):"<<endl 

     for(i=0i<3i++){ 

         cin>>c[i] 

     } 

 } 

 //输入经度 

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=2000i<yeari++){ 

         if(leap_year(i)) a=a+366 

         else a=a+365 

     } 

     if(leap_year(year)){ 

         for(i=0i<month-1i++){ 

             a=a+days_of_month_2[i] 

         } 

     } 

     else { 

         for(i=0i<month-1i++){ 

             a=a+days_of_month_1[i] 

         } 

     } 

     a=a+date 

     return a 

 } 

 //求从格林威治时间公元2000年1月1日到计算日天数days 

 long double t_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){ 

     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(long 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){ 

     return (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))) 

 } 

 //求太阳偏差 

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_longitude*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/180)-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){ 

     return (UTo-(GHA+glong+e)) 

 } 

 //求日出时间 

long double UT_set(long double UTo, long double GHA, long double glong, long double e){ 

     return (UTo-(GHA+glong-e)) 

 } 

 //求日落时间 

long double result_rise(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_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) 

         cout<<"The 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 cout<<"The 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) 

         cout<<"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<<"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" 

 } 

 //打印结果 

         

int main(){ 

     long double UTo=180.0 

     int year,month,date 

     long double glat,glong 

     int c[3] 

     input_date(c) 

     year=c[0] 

     month=c[1] 

     date=c[2] 

     input_glat(c) 

     glat=c[0]+c[1]/60+c[2]/3600 

     input_glong(c) 

     glong=c[0]+c[1]/60+c[2]/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),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) 

     output(rise,set,glong) 

     system("pause") 

     return 0 

 }


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11888795.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存