背景:
2003年记录的小程序
已知某天是星期几,不使用时间函数计算一个日期是星期几。
不知道谁写的函数,有些复杂了,但运行正常。
觉得先计算已知日期当年1月1号是星期几,再加上间隔年份+闰年数+所求日期是一年中的第几天比较简单。
代码
#include<iostream>
#include<conio.h>
using namespace std;
//2003年记录的小程序
// 已知某天是星期几,不使用时间函数计算一个日期是星期几。
//不知道谁写的函数,有些复杂了,但运行正常。
//觉得先计算已知日期的1月1号是星期几,再加上年份+闰年数比较简单。
const char* getWeekDay(int rd, int rm, int ry);
int mainWeekDay()
{
int rd, rm, ry;
cout << "Enter REQUIRED date (DD MM YYYY) : ";
cin >> rd >> rm >> ry;
cout << "It's a " << getWeekDay( rd, rm, ry) << " !!";
return getchar();
}
const char* getWeekDay(int rd, int rm, int ry) {
int Ydiff, Ddiff, Mdiff;
const char* DAY[7] = { "Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday" };
int cd, cm, cy, cs, rs, i;
cd = 19; cm = 2; cy = 2001; cs = 2; // setting 19 feb 2001 , Monday
// difference in years
Ydiff = cy - ry;
// find no of leap years
if (cy >= ry)
{
for (i = cy; i >= ry; i--)
{
if ((i % 100) == 0) // for a century
{
if ((i % 400) == 0) { Ydiff++; }
}
else
{
if ((i % 4) == 0) { Ydiff++; }
}
}
}
else
{
for (i = cy; i < ry; i++)
{
if ((i % 100) == 0) // for a century
{
if ((i % 400) == 0) { Ydiff--; }
}
else
{
if ((i % 4) == 0) { Ydiff--; }
}
}
}
Ydiff = Ydiff % 7;//years*(365%7=1)+leap years ----重要:年份+闰年数
Ddiff = (cd - rd) % 7;
rs = cs - (Ydiff + Ddiff) % 7;
rs = rs % 7;
//difference in months
Mdiff = cm - rm;
if (Mdiff < 0)
{
for (i = cm; i < rm; i++)
{
switch (i)
{
//... 省略若干行
}
}
rs = rs % 7;
}
else if (Mdiff > 0)
{
for (i = cm; i > rm; i--)
{
switch (i)
{
//... 省略若干行
}
}
rs = rs % 7;
}
if (rs <= 0) { rs = 7 + rs; }
const char* weekDay = DAY[rs - 1];
return weekDay;
}