求VC++6.0下的万年历程序

作者&投稿:点京 (若有异议请与网页底部的电邮联系)
VC++编程,万年历~

/*编制万年历
*/
#include
long int f(int year,int month)
{
/*如果月<3,f(年,月) = 年-1;否则f(年,月) = 年*/
if(month<3) return year-1;
else return year;
}
long int g(int month)
{
/*如果月<3,g(月) = 月+13;否则g(月)=月+1*/
if(month<3) return month+13;
else return month + 1;
}

long int n(int year, int month, int day)
{
/*N=1461*f(年,月)/4 + 153*g(月) + 日*/
return 1461L * f(year,month)/4 + 153L*g(month)/5 + day;
}

//计算星期几,星期日为返回0
int w(int year, int month, int day)
{
/*w=(N-621049%7(0<=w<7)*/
return (int)((n(year,month,day)%7 - 621049L%7 + 7)%7);
}

int date[12][6][7];
int day_tb1[][12]={{31,28,31,30,31,30,31,31,30,31,30,31},
{31,29,31,30,31,30,31,31,30,31,30,31}};

main()
{
int sw,leap,i,j,k,wd,day;
int year;
char title[] = " SUN MON TUE WED THU FRI SAT";

printf("Please input the year whose calendar you want to know: ");
scanf("%d*c",&year); /*输入年份值和回车*/
sw = w(year,1,1);
leap= year%4==0 && year%100||year%400==0;
for(i=0; i<12; i++)
for(j=0; j<6; j++)
for(k=0; k<7; k++)
date[i][j][k]=0; /*日期表置0*/
for(i=0; i<12; i++) /*一年12个月*/
for(wd=0,day=1; day<=day_tb1[leap][i]; day++)
{/*将第i+1月的日期填入日期表*/
date[i][wd][sw] = day;
sw=++sw%7; /*每星期7天,以0~6计数*/
if(sw==0) wd++; /*日期表每七天一行,星期天开始新的一行*/
}

printf("
|==================The Calendar of Year %d ======================|
|",year);
for(i=0; i<6; i++)
{/*先测算第i+1月和第i+7月的最大星期数*/
for(wd=0,k=0; k<7; k++) /*日期表的第6行有日期,则wd != 0*/
wd += date[i][5][k] + date[i+6][5][k];
wd=wd?6:5;
printf("%2d %s %2d %s|
|",i+1,title,i+7,title);
for(j=0; j<wd; j++)
{
printf(" "); /*输出3个空白字符*/
/*左栏为敌i+1月,右栏为第i+7月*/
for(k=0; k<7; k++)
if(date[i][j][k])
printf("%4d",date[i] [j] [k]);
else printf(" ");
printf(" ");/*输出6个空白字符*/
for(k=0; k<7; k++)
if(date[i+6] [j] [k])
printf("%4d",date[i+6] [j] [k]);
else printf(" ");
printf(" |
|");
}
}
puts("==================================================================|");
puts("
Press any key to quit...");
getch();
}

这是个万年历,你新建个对话框工程,加个文本框,接受输入,再加个输出框,计算星期几用w(year,month,day),计算第几周就简单了吧,先判断是否是闰年程序里已经有了,然后根据年月日和每个月的天数,判断已经过了多少天,再除以7,注意判断是不是整除的情况,很简单了,自己写吧,别太懒 不然学不到东西的

#include
#include
using
namespace
std;
bool
is_leap_year(int
y)//year
has
366
or
355
{
return((y%4==0&&y%100!=0||y%400==0));
}
int
first_day(int
y)//the
first
day
is?
{
long
n;
n=y*365;
for(int
i=1;i<y;i++)
n+=is_leap_year(i);
return
n%7;
}
int
month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int
first_day_month(int
y,int
m)
{
if(is_leap_year(y))
month[2]=29;
else
month[2]=28;
int
sum=0;
for(int
i=1;i<m;i++)
sum+=month[i];
int
d=(sum+first_day(y))%7;
return
d;
}
void
print(int
y,int
m)
{
cout<<setw(6)<<"Sun
"<<"Mon
"<<"Tues
"<<"Wed
"<<"Thurs
"<<"Fir
"
<<"Sat
"<<endl;
int
first=first_day_month(y,m);
if(first>0)
cout<<setw(6*first)<<"
";
for(int
j=1;j<=month[m];j++)
{
cout<<setw(5)<<j<<"
";
if((j+first)%7==0)
cout<<endl;
}
cout<<endl;
}
int
main()
{
int
y,m;
cout<<"enter
the
year
";
cin>>y;
cout<<"enter
the
month
";
cin>>m;
print(y,m);
return
0;
}
超基本的算法。。。。

#include <stdio.h>

/*
呼叫时须设定 Souce 的值, 若为 0 则为西历转农历, 否则为农历转西历.
然后视输入为西历或农历来设定西历或农历的年月日.
转换后的年月日会填入结构中(农历或西历 ), 以及该日为星期几, 天干地支.

若函式的返回值为
0 表示没有错误, 1 为输入之年份错误, 2 为输入之月份错误, 3 为输入之日期错误.

输入之西历年须在 1937 - 2031 间
输入之农历年须在 1936 - 2030 间
若须扩充,则增加 LunarCal[],修改FIRSTYEAR

*/

struct ConvDate
{
int Source; // ==0 则输入日期为西历, !=0 则输入为农历
int SolarYear; //输出或输入之西历年份 YYYY
int SolarMonth; //西历月 MM
int SolarDate; //西历日 DD
int LunarYear; //输出或输入之农历年份 YYYY
int LunarMonth; //农历月 负数表示闰月
int LunarDate; //农历日
int Weekday; //该日为星期几 (0星期日 1星期一 2星期二 3星期三 4星期四 5星期五 6星期六)
int Kan; //该日天干(0甲 1乙 2丙 3丁 4戊 5己 6庚 7辛 8壬 9癸)
int Chih; //该日地支(0子 1丑 2寅 3卯 4辰 5巳 6午 7未 8申 9酉 10戌 11亥)
};

struct tagLunarCal
{
char BaseDays; //西历 1 月 1 日到农历正月初一的累积日数
char Intercalation; //闰月月份. 0==此年没有闰月
char BaseWeekday; //此年西历 1 月 1 日为星期几再减 1
char BaseKanChih; //此年西历 1 月 1 日到干支序号减 1
char MonthDays[13]; //此农历年每月之大小, 0==小月(29日), 1==大月(30日)
};

struct tagLunarCal LunarCal[] = {
{ 23, 3, 2, 17, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0 }, /* 1936 */
{ 41, 0, 4, 23, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1 },
{ 30, 7, 5, 28, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1 },
{ 49, 0, 6, 33, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 },
{ 38, 0, 0, 38, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, /* 1940 */
{ 26, 6, 2, 44, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0 },
{ 45, 0, 3, 49, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 },
{ 35, 0, 4, 54, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 },
{ 24, 4, 5, 59, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1 }, /* 1944 */
{ 43, 0, 0, 5, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1 },
{ 32, 0, 1, 10, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1 },
{ 21, 2, 2, 15, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 },
{ 40, 0, 3, 20, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 }, /* 1948 */
{ 28, 7, 5, 26, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 },
{ 47, 0, 6, 31, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1 },
{ 36, 0, 0, 36, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 },
{ 26, 5, 1, 41, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1 }, /* 1952 */
{ 44, 0, 3, 47, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1 },
{ 33, 0, 4, 52, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0 },
{ 23, 3, 5, 57, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1 },
{ 42, 0, 6, 2, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1 }, /* 1956 */
{ 30, 8, 1, 8, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0 },
{ 48, 0, 2, 13, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0 },
{ 38, 0, 3, 18, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1 },
{ 27, 6, 4, 23, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0 }, /* 1960 */
{ 45, 0, 6, 29, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0 },
{ 35, 0, 0, 34, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 },
{ 24, 4, 1, 39, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0 },
{ 43, 0, 2, 44, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0 }, /* 1964 */
{ 32, 0, 4, 50, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1 },
{ 20, 3, 5, 55, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0 },
{ 39, 0, 6, 0, 1, 1, 0, 1, 1, 0, 0, 1, 0, 1, 0, 1, 0 },
{ 29, 7, 0, 5, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1 }, /* 1968 */
{ 47, 0, 2, 11, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 },
{ 36, 0, 3, 16, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0 },
{ 26, 5, 4, 21, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1 },
{ 45, 0, 5, 26, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1 }, /* 1972 */
{ 33, 0, 0, 32, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1 },
{ 22, 4, 1, 37, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1 },
{ 41, 0, 2, 42, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1 },
{ 30, 8, 3, 47, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1 }, /* 1976 */
{ 48, 0, 5, 53, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1 },
{ 37, 0, 6, 58, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 },
{ 27, 6, 0, 3, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0 },
{ 46, 0, 1, 8, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0 }, /* 1980 */
{ 35, 0, 3, 14, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 1 },
{ 24, 4, 4, 19, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1 },
{ 43, 0, 5, 24, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1 },
{ 32, 10, 6, 29, 1, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1 }, /* 1984 */
{ 50, 0, 1, 35, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0 },
{ 39, 0, 2, 40, 0, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1 },
{ 28, 6, 3, 45, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1, 0, 0 },
{ 47, 0, 4, 50, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 }, /* 1988 */
{ 36, 0, 6, 56, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0 },
{ 26, 5, 0, 1, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 1 },
{ 45, 0, 1, 6, 0, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0 },
{ 34, 0, 2, 11, 0, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0 }, /* 1992 */
{ 22, 3, 4, 17, 0, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0 },
{ 40, 0, 5, 22, 1, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0 },
{ 30, 8, 6, 27, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1, 0, 1 },
{ 49, 0, 0, 32, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 0, 0, 1 }, /* 1996 */
{ 37, 0, 2, 38, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 },
{ 27, 5, 3, 43, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1, 1, 0, 1 },
{ 46, 0, 4, 48, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1 },
{ 35, 0, 5, 53, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1 }, /* 2000 */
{ 23, 4, 0, 59, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 },
{ 42, 0, 1, 4, 1, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 },
{ 31, 0, 2, 9, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0 },
{ 21, 2, 3, 14, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1 }, /* 2004 */
{ 39, 0, 5, 20, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1 },
{ 28, 7, 6, 25, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 1 },
{ 48, 0, 0, 30, 0, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1 },
{ 37, 0, 1, 35, 1, 0, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1 }, /* 2008 */
{ 25, 5, 3, 41, 1, 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 },
{ 44, 0, 4, 46, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1 },
{ 33, 0, 5, 51, 1, 0, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 },
{ 22, 4, 6, 56, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 }, /* 2012 */
{ 40, 0, 1, 2, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0 },
{ 30, 9, 2, 7, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1 },
{ 49, 0, 3, 12, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 0, 1 },
{ 38, 0, 4, 17, 1, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0 }, /* 2016 */
{ 27, 6, 6, 23, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1 },
{ 46, 0, 0, 28, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 0 },
{ 35, 0, 1, 33, 0, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0 },
{ 24, 4, 2, 38, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1 }, /* 2020 */
{ 42, 0, 4, 44, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1, 0, 1 },
{ 31, 0, 5, 49, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0 },
{ 21, 2, 6, 54, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1 },
{ 40, 0, 0, 59, 0, 1, 0, 0, 1, 0, 1, 1, 0, 1, 1, 0, 1 }, /* 2024 */
{ 28, 6, 2, 5, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0 },
{ 47, 0, 3, 10, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 0, 1 },
{ 36, 0, 4, 15, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0, 1 },
{ 25, 5, 5, 20, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, 1, 0 }, /* 2028 */
{ 43, 0, 0, 26, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 1, 0, 1 },
{ 32, 0, 1, 31, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0 },
{ 22, 3, 2, 36, 0, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 0 }};

const int FIRST_YEAR = 1936; // The first year in LunarCal[]
const int LAST_YEAR = FIRST_YEAR + sizeof(LunarCal)/sizeof(struct tagLunarCal) - 1;

// 西历年平年每月之日数
int arr_nDays[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};

// 西历年每月之累积日数, 平年与闰年 第一行平年,第二行闰年
int SolarDays[2][14] = {
{0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365, 396 },
{0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335, 366, 397 }};

const char NO_ERROR = 0;
const char INPUT_YEAR_ERROR = 1;
const char INPUT_MONTH_ERROR = 2;
const char INPUT_DAY_ERROR = 3;

char CalConv( struct ConvDate *_stDate );

int IsLeap(int _nYear );

int main(int argc, char*argv[])
{
struct ConvDate stConvDate;
printf("0. 阳历转化为阴历\n1. 阴历转化为阳历\n");
scanf("%d",&stConvDate.Source);
if (stConvDate.Source == 0)
{
printf("输入年份:");
scanf("%d",&stConvDate.SolarYear);
printf("\n输入月份:");
scanf("%d",&stConvDate.SolarMonth);
printf("\n输入日期:");
scanf("%d",&stConvDate.SolarDate);
}
else
{
printf("输入年份:");
scanf("%d",&stConvDate.LunarYear);
printf("\n输入月份:");
scanf("%d",&stConvDate.LunarMonth);
printf("\n输入日期:");
scanf("%d",&stConvDate.LunarDate);
}

switch(CalConv(&stConvDate))
{
case INPUT_YEAR_ERROR:
printf("INPUT_YEAR_ERROR\n");
break;
case INPUT_MONTH_ERROR:
printf("INPUT_MONTH_ERROR\n");
break;
case INPUT_DAY_ERROR:
printf("INPUT_DAY_ERROR\n");
break;
default:
printf("YYMMDD: %d %d %d Week:%d Kan:%d Chih:%d\n",
stConvDate.LunarYear,stConvDate.LunarMonth,stConvDate.LunarDate,
stConvDate.Weekday,stConvDate.Kan,stConvDate.Chih);
}

return 0;
}

// 求此西历年是否为闰年, 返回 0 为平年, 1 为闰年
int IsLeap(int _nYear )
{
if ( _nYear % 400 == 0 ) return 1;
else if ( _nYear % 100 == 0 ) return 0;
else if ( _nYear % 4 == 0 ) return 1;
else return 0;
}

// 西历农历转换
char CalConv( struct ConvDate *_stDate )
{
int nIsLeap;
int nMonthDay;
int nSolarMonth;
int nYearOffset;
int im;
int l1;
int l2;
int nDayOfYear;
int i;
int lm;
int nKanChih;
if ( _stDate->Source == 0 ) // ==0 输入阳历,否则输出阴历
{
if ( _stDate->SolarYear <= FIRST_YEAR || _stDate->SolarYear > LAST_YEAR ) //检查输入年份错误
{
return INPUT_YEAR_ERROR;
}

nSolarMonth = _stDate->SolarMonth - 1; //对齐数组下标

if ( nSolarMonth < 0 || nSolarMonth > 11 ) //检查输入月份错误
{
return INPUT_MONTH_ERROR;
}

nIsLeap = IsLeap( _stDate->SolarYear ); //判断是否闰年 闰年为1 平年为0

if ( nSolarMonth == 1 ) // 根据平年闰年计算 2月天数
{
nMonthDay = nIsLeap + 28; // 是闰年 2 月加一天
}
else //其他月份天数
{
nMonthDay = arr_nDays[nSolarMonth];
}

if ( _stDate->SolarDate < 1 || _stDate->SolarDate > nMonthDay ) // 检查输入日期是否有误
{
return INPUT_DAY_ERROR;
}

nYearOffset = _stDate->SolarYear - FIRST_YEAR; //年份在表里面的偏移,对齐数组

nDayOfYear = SolarDays[nIsLeap][nSolarMonth] + _stDate->SolarDate; //每个阳历年的第几天

_stDate->Weekday = ( nDayOfYear + LunarCal[nYearOffset].BaseWeekday ) % 7; //算出星期几

nKanChih = nDayOfYear + LunarCal[nYearOffset].BaseKanChih; //由天干地支的基数得出

_stDate->Kan = nKanChih % 10; //算天干

_stDate->Chih = nKanChih % 12; //算地支

if ( nDayOfYear < LunarCal[nYearOffset].BaseDays + 1 ) //过了元旦,但还没过春节
{
nYearOffset--;
_stDate->LunarYear = _stDate->SolarYear - 1;
nIsLeap = IsLeap( _stDate->LunarYear );
nSolarMonth += 12;
nDayOfYear = SolarDays[nIsLeap][nSolarMonth] + _stDate->SolarDate;
}
else //年份一致的时间
{
_stDate->LunarYear = _stDate->SolarYear;
}

l1 = LunarCal[nYearOffset].BaseDays;
for ( i=0; i<13; i++ )
{
l2 = l1 + LunarCal[nYearOffset].MonthDays[i] + 29;
if ( nDayOfYear <= l2 )
break;
l1 = l2;
}
_stDate->LunarMonth = i + 1;
_stDate->LunarDate = nDayOfYear - l1;
im = LunarCal[nYearOffset].Intercalation;
if ( im != 0 && _stDate->LunarMonth > im )
{
_stDate->LunarMonth--;
if ( _stDate->LunarMonth == im )
_stDate->LunarMonth = -im;
}
if ( _stDate->LunarMonth > 12 )
_stDate->LunarMonth -= 12;
}
else //输入阴历,输出阳历
{
if ( _stDate->LunarYear < FIRST_YEAR || _stDate->LunarYear >= LAST_YEAR ) //输入之年份错误
{
return INPUT_YEAR_ERROR;
}
nYearOffset = _stDate->LunarYear - FIRST_YEAR;
im = LunarCal[nYearOffset].Intercalation;
lm = _stDate->LunarMonth;
if ( lm < 0 )
{
if ( lm != -im ) return INPUT_MONTH_ERROR;
}
else if ( lm < 1 || lm > 12 ) return INPUT_MONTH_ERROR;
if ( im != 0 )
{
if ( lm > im ) lm++;
else if ( lm == -im ) lm = im + 1;
}
lm--;
if ( _stDate->LunarDate > LunarCal[nYearOffset].MonthDays[lm] + 29 ) return INPUT_DAY_ERROR;
nDayOfYear = LunarCal[nYearOffset].BaseDays;
for ( i=0; i<lm; i++ )
{
nDayOfYear += LunarCal[nYearOffset].MonthDays[i] + 29;
}
nDayOfYear += _stDate->LunarDate;
nIsLeap = IsLeap( _stDate->LunarYear );
for ( i=13; i>=0; i-- )
{
if ( nDayOfYear > SolarDays[nIsLeap][i] ) break;
}

_stDate->SolarDate = nDayOfYear - SolarDays[nIsLeap][i];

if ( i <= 11 )
{
_stDate->SolarYear = _stDate->LunarYear;
_stDate->SolarMonth = i + 1;
}
else
{
_stDate->SolarYear = _stDate->LunarYear + 1;
_stDate->SolarMonth = i - 11;
}

nIsLeap = IsLeap( _stDate->SolarYear );

nYearOffset = _stDate->SolarYear - FIRST_YEAR;

nDayOfYear = SolarDays[nIsLeap][_stDate->SolarMonth-1] + _stDate->SolarDate;

_stDate->Weekday = ( nDayOfYear + LunarCal[nYearOffset].BaseWeekday ) % 7;

nKanChih = nDayOfYear + LunarCal[nYearOffset].BaseKanChih;

_stDate->Kan = nKanChih % 10;

_stDate->Chih = nKanChih % 12;
}

return NO_ERROR;
}

VC自带的有年历空间!添加即可


如何在vc6.0下编写一个程序?
1、首先打开vc6.0, 新建一个项目。2、然后添加头文件。3、添加main主函数。4、定义一个两个数相加的函数binSubtracton。5、在main函数定义int了性number1,number2, binSub。6、使用scanf给变量赋值。7、调用binAddition、binSubtracton。8、运行程序,看看结果就完成了。

为什么在VC6.0下编译不了C++程序?
这个是因为vc的bug。需要重新安装vc。1、打开VC6.0++,选择文件--新建。2、新建一个控制台应用工程,命名为demo。3、选择一个空的工程。4、此次,新建一个C++源文件。5、键入一段简单的C程序。6、编译运行。7、运行的效果如图。完成。

vc++6.0和VC2017区别
一、含义不同 Visual C ++ 6.0,称为VC或VC6.0,是Microsoft的C ++编译器,可将“高级语言”转换为“机器语言(低级语言)”程序。VC ++ 2017运行时库是vc ++ 2017运行时库,它是Microsoft C ++开发工具。二、版本时间不同 VC6.0是革命性的产品。许多公司和个人仍然使用它。 VC6.0是C语言...

VC6.0(VisualC++6.0)使用教程(使用VC6.0编写C语言程序)
1、新建Win32 Console Application工程,在你的电脑上找到图一(也就是VC6.0,当然你要事先安装好这个软件),双击打开VC6.0。在菜单栏中选择“文件->新建”(也可以直接用快捷键Ctrl+n),弹出下面的框框。2、选择你C语言文件的存储位置。如下图的步骤,先点击位置右下方的三个点,会弹出最右面...

如何在VC6.0下创建一个C语言程序?
1.启动 Visual Studio 2.选择菜单 File(文件)--> New(新建) --> Project(项目),进入 New Project(新建项目)对话框 3.在Project Types(项目类型)中,选择Visual C++ 4.在Templates(模板)中选择 Win32 Project(Win32项目)5.在 Name(名称)文本框中,写Project(项目)的名字,比如...

VC++6.0下新建工程中有17个选项,都是做什么用的?
1.AppWizardi创建一个新的COM组件向导,如WORD中使用的公式编辑器就是一个COM组件。2.群集资源类型向导创建可在任何地方使用的资源项,如字体。3.这是一个为高端用户定制的向导。4.顾名思义,数据库项目用于创建数据库。5.DevStudio插件向导是微软可视化工具系列的向导。6.ExtendedStoredProc向导扩展...

vc++6.0如何运行?
1、进入vc++6.0 后,在菜单栏里找到"文件"并点击它,出现以下界面。然后点击新建。2、接下来,先点击"文件",然后点击"c++ Source File",然后输入文件名和确定文件位置,最后点击"确定",如图所示。3、出现以下的界面,在界面中输入你要运行的源代码,如图所示。4、然后在工具栏点击"Build"按钮,如图...

如何在VC++6.0下添加一个按钮控件
1、首先,点击Insert插入按钮。2、然后,接着点击File Text按钮。3、接下来,找到Insert File文件。4、这个时候,就可以在这里设置查找范围。5、此时,还可以点击此处浏览文件。6、最后,点击Ok按钮即可成功确定。注意事项:VC++集成了便利的除错工具,特别是集成了微软Windows视窗操作系统应用程序接口(...

vc++6.0哪里下载?
VC运行库下载地址 VC运行库是Visual C++运行库,是Windows操作系统下的开发环境组件之一。若要下载VC运行库,可以参考以下途径:一、官方渠道下载 1. 访问Microsoft官方网站。2. 在搜索栏中输入“Visual C++ Redistributable Packages”或相关关键词。3. 进入下载页面,根据需求选择相应的版本进行下载。二、...

vc6.0怎么运行程序?
1、打开VC++6.0,选择“文件”→“新建”。2、然后选择“文件”项,选择“C++ Source File”项,并在“文件名”项目下输入自定义的文件名,单击“确定”。3、出现以下的界面,在界面中输入你要运行的源代码。4、然后在工具栏点击编译按钮"Build",调试程序,查看有无错误。5、然后在...

三亚市13334203138: 菜鸟求助怎样用vc++6.0编写万年历程序 -
徭虾炎可: 1、应在主函数中对函数sub进行初始化 在{ 下面增加代码:int sub(int x); 2、函数int sub(x)应为int sub(int x) 3、函数sub里面又加了int x;x重定义错误,去掉int x;这行代码 修改后的代码为: #include<stdio.h> void main() { int sub(int x); int x,m; ...

三亚市13334203138: 求一个c语言编写的万年历系统
徭虾炎可: #include<stdio.h>long int f(int year,int month){//f(年,月)=年-月,如月<3;否则,f(年,月)=年 if (month <3) return year-1; else return year;}long int g(int month){//g( 月)=月+13,如月<3;否则,g(月)=月+1 if(month<3) return month + ...

三亚市13334203138: 求VC++6.0下的万年历程序 -
徭虾炎可: #include /* 呼叫时须设定 Souce 的值, 若为 0 则为西历转农历, 否则为农历转西历. 然后视输入为西历或农历来设定西历或农历的年月日. 转换后的年月日会填入结构中(农历或西历 ), 以及该日为星期几, 天干地支. 若函式的返回值为 0 表示...

三亚市13334203138: 求能在c++6.0编译器下运行的用c语言编写的万年历程序 及详细注释 -
徭虾炎可: 何必那么麻烦,打开vc,选择工程MFC.exe,然后选择第三个普通对话框,再选择下面完成,然后进入对话框页面,旁边有控件列表,然后把日历控件拉进去就好,更多操作可以定义它的类向导然后使用它的类函数编写程序最后完成

三亚市13334203138: 救助用c语言(VC++ 6.0)编的万年历,能显示阴历,非常感谢! -
徭虾炎可: #includeint *year1,*month1; void main() { int year,month,j,xingqi,g,z,wk;int hanshu1(long);int hanshu2(long); int hanshu3(int);int hanshu4(int,int,int);long count1;int i; printf("please input year and month:\nyear:\n"); scanf("%d",&year); year1=&...

三亚市13334203138: c语言制作日历问题,求高手解答,非常紧急~最好能给出整个题目的代码 加上适当的注释谢谢 -
徭虾炎可: 多看看就会懂的,就不解释了 #include <stdio.h> long int f(int year, int month) {if(month < 3) return year - 1;else return year; } long int g(int month) {if(month < 3) return month + 13;else return month + 1; } long int n(int year, int month, int day) {...

三亚市13334203138: vc++万年历的设计求高手啊!!急急!!!!!!! -
徭虾炎可: 我这有一个以前用C++写的万年历,不过没有你说的什么节假日的功能,不过希望对你有点帮助吧.#include#include void main() {int a=0;int y=0;int t=0;cout cin>>y;for(int i=1;i {if(i%4==0&&i%100!=0||i%400==0)a+=366;elsea+=365;}...

三亚市13334203138: 急:C++程序设计, 万年历:要求输入年份,输出该年各月的日历 ,谢谢各位大大了 -
徭虾炎可: 计算每年的第一天是周几,这个道理很简单400年的天数刚好是7的倍数,所以只求余下的那些年的天数就可 还有一点就是每年365天,364是7的倍数,所以一年多出一天,在加上闰年的多出来的那一天 int year(int ye) { int y=ye%400; int i; int dat...

三亚市13334203138: 求c++程序,一个万年历程序设计,要求去如下.. 17. 万年历程序设计(2人) 天数、一日期减去 -
徭虾炎可: //Date.h#include using namespace std; class Date{ public: static char week[8][10]; static int Form[2][12]; Date(); Date(int y,int m,int d); Date(const Date&); Date operator+(int days); Date operator-(int days); int operator-(const Date &b); void ...

三亚市13334203138: 求万年历VC6.0 源代码.高手请指教
徭虾炎可: #include <stdio.h> #include <conio.h> typedef enum { sun, mon, tue, wed, thr, fri, sat } Week; int main() { int check_year(int *); int check_day(int * , int *); Week week(int *); int year , temp_year; FILE * fp; if((fp=fopen("CAL.txt","a+"))==NULL) { ...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网