C++万年历课程设计报告.docx

上传人:b****3 文档编号:2785887 上传时间:2022-11-15 格式:DOCX 页数:10 大小:16.77KB
下载 相关 举报
C++万年历课程设计报告.docx_第1页
第1页 / 共10页
C++万年历课程设计报告.docx_第2页
第2页 / 共10页
C++万年历课程设计报告.docx_第3页
第3页 / 共10页
C++万年历课程设计报告.docx_第4页
第4页 / 共10页
C++万年历课程设计报告.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

C++万年历课程设计报告.docx

《C++万年历课程设计报告.docx》由会员分享,可在线阅读,更多相关《C++万年历课程设计报告.docx(10页珍藏版)》请在冰豆网上搜索。

C++万年历课程设计报告.docx

C++万年历课程设计报告

#ifndef_CALENDAR_H

#define_CALENDAR_H

#include

structmyDATE{

intyear;

intmonth;

intday;

boolisRunYue;

};

classcalendar{

public:

calendar(){};

~calendar(){};

LONGlDaysFrom1900(myDATEdate);//date与1900年相差的天数

UINTlYearDays(UINTy);//农历y年的总天数

UINTleapDays(UINTy);//传回农历y年闰月的天数

UINTleapMonth(UINTy);//传回农历y年闰哪个月1-12,没闰传回0

UINTmonthDays(UINTy,UINTm);//传回农历y年m月的总天数

myDATELunar(myDATEdate);//输入阳历日期,返回阴历日期

char*dayOfWeek(myDATEdate);//输入阳历日期,返回星期几

char*getLunarString(myDATEdate);//输入阴历日期,得到表示农历的字串

UINTsolarDays(UINTy,UINTm);//传回国历y年某m+1月的天数

private:

charm_slunar[100];//用于存储农历信息

staticDWORDlunarInfo[];//

staticUINTsolarmonth[];

staticcharsSolarTerm[];

staticDWORDdTermInfo[];

staticcharsFtv[];

};

#endif

//#include"calendar.h"

#include

DWORDcalendar:

:

lunarInfo[]={

0x04bd8,0x04ae0,0x0a570,0x054d5,0x0d260,0x0d950,0x16554,0x056a0,0x09ad0,0x055d2,

0x04ae0,0x0a5b6,0x0a4d0,0x0d250,0x1d255,0x0b540,0x0d6a0,0x0ada2,0x095b0,0x14977,

0x04970,0x0a4b0,0x0b4b5,0x06a50,0x06d40,0x1ab54,0x02b60,0x09570,0x052f2,0x04970,

0x06566,0x0d4a0,0x0ea50,0x06e95,0x05ad0,0x02b60,0x186e3,0x092e0,0x1c8d7,0x0c950,

0x0d4a0,0x1d8a6,0x0b550,0x056a0,0x1a5b4,0x025d0,0x092d0,0x0d2b2,0x0a950,0x0b557,

0x06ca0,0x0b550,0x15355,0x04da0,0x0a5d0,0x14573,0x052d0,0x0a9a8,0x0e950,0x06aa0,

0x0aea6,0x0ab50,0x04b60,0x0aae4,0x0a570,0x05260,0x0f263,0x0d950,0x05b57,0x056a0,

0x096d0,0x04dd5,0x04ad0,0x0a4d0,0x0d4d4,0x0d250,0x0d558,0x0b540,0x0b5a0,0x195a6,

0x095b0,0x049b0,0x0a974,0x0a4b0,0x0b27a,0x06a50,0x06d40,0x0af46,0x0ab60,0x09570,

0x04af5,0x04970,0x064b0,0x074a3,0x0ea50,0x06b58,0x055c0,0x0ab60,0x096d5,0x092e0,

0x0c960,0x0d954,0x0d4a0,0x0da50,0x07552,0x056a0,0x0abb7,0x025d0,0x092d0,0x0cab5,

0x0a950,0x0b4a0,0x0baa4,0x0ad50,0x055d9,0x04ba0,0x0a5b0,0x15176,0x052b0,0x0a930,

0x07954,0x06aa0,0x0ad50,0x05b52,0x04b60,0x0a6e6,0x0a4e0,0x0d260,0x0ea65,0x0d530,

0x05aa0,0x076a3,0x096d0,0x04bd7,0x04ad0,0x0a4d0,0x1d0b6,0x0d250,0x0d520,0x0dd45,

0x0b5a0,0x056d0,0x055b2,0x049b0,0x0a577,0x0a4b0,0x0aa50,0x1b255,0x06d20,0x0ada0

};

UINTcalendar:

:

solarmonth[]={31,28,31,30,31,30,31,31,30,31,30,31};

UINTcalendar:

:

lYearDays(UINTy)

{

UINTi,sum=348;

for(i=0x8000;i>0x8;i>>=1)

{

sum+=(lunarInfo[y-1900]&i)?

1:

0;

}

return(sum+leapDays(y));

}

UINTcalendar:

:

leapDays(UINTy)

{

if(leapMonth(y))

{

return(lunarInfo[y-1900]&0x10000)?

30:

29;

}

else

{

return0;

}

}

UINTcalendar:

:

leapMonth(UINTy)

{

returnlunarInfo[y-1900]&0xf;

}

UINTcalendar:

:

monthDays(UINTy,UINTm)

{

return(lunarInfo[y-1900]&(0x10000>>m))?

30:

29;

}

LONGcalendar:

:

lDaysFrom1900(myDATEdate)

{

LONGdays;

days=365*date.year+(date.year-1)/4-(date.year-1)/100+(date.year-1)/400-

(365*1900+(1900-1)/4-(1900-1)/100+(1900-1)/400);

for(inti=0;i

{

days+=solarmonth[i];

}

days+=date.day;

if((date.year%4==0&&date.year%100!

=0)||date.year%400==0)

{

if(date.month>2)

{

days++;

}

}

returndays;

}

myDATEcalendar:

:

Lunar(myDATEdate)

{

LONGoffset;

inti,leap=0,temp=0;

myDATEretdate;

offset=lDaysFrom1900(date)-30;

for(i=1900;i<2050&&offset>0;i++)

{

temp=lYearDays(i);

offset-=temp;

}

if(offset<0)

{

offset+=temp;

i--;

}

retdate.year=i;

leap=leapMonth(i);

boolisLeap=false;

for(i=1;i<13&&offset>0;i++)

{

if(leap>0&&i==(leap+1)&&isLeap==false)

{

--i;

isLeap=true;

temp=leapDays(retdate.year);

}

else

{

temp=monthDays(retdate.year,i);

}

if(isLeap==true&&i==(leap+1))

{

isLeap=false;

}

offset-=temp;

}

if(offset==0&&leap>0&&i==leap+1)

{

if(isLeap)

{

isLeap=false;

}

else

{

isLeap=true;

--i;

}

}

if(offset<=0)

{

offset+=temp;

--i;

}

retdate.month=i;

retdate.day=offset;

retdate.isRunYue=isLeap;

returnretdate;

}

char*calendar:

:

getLunarString(myDATEdate)

{

TCHARszNongli[30],szNongliDay[10],szShuXiang[10];

constchar*cTianGan[]={"甲","乙","丙","丁","戊","己","庚","辛","壬","癸"};/*天干名称*/

constchar*cDiZhi[]={"子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥"};/*地支名称*/

constchar*cShuXiang[]={"鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪"};/*属相名称*/

constchar*cDayName[]={"*","初一","初二","初三","初四","初五",/*农历日期名*/

"初六","初七","初八","初九","初十",

"十一","十二","十三","十四","十五",

"十六","十七","十八","十九","二十",

"廿一","廿二","廿三","廿四","廿五",

"廿六","廿七","廿八","廿九","三十"};

constchar*cMonName[]={"*","正","二","三","四","五","六","七","八","九","十","十一","腊"};

/*--生成农历天干、地支、属相==>wNongli--*/

intnShuXiang=((date.year-4)%60)%12;

if(nShuXiang<0||nShuXiang>=sizeof(cShuXiang)/sizeof(cShuXiang[0]))

{

returnNULL;

}

wsprintf(szShuXiang,"%s",cShuXiang[nShuXiang]);

intnTianGan=((date.year-4)%60)%10;

if(nTianGan<0||n

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 经管营销 > 经济市场

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1