背景:

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;
}