[c] 万年历

Rohana ·
更新时间:2024-11-11
· 572 次阅读

#include 
#include 
#include 
#define str "   SUN   MON  TUE   WED   THU   FRI   SAT   "
void menu();         //操作菜单
int leap(int year);        //判断某年是不是闰年
int days_month(int year, int month);        //返回某月的天数
int someday(int year, int month, int day);    //计算某天是星期几
void search_month(int year, int month);        //输出某月的日历
void search_someday(int year, int month, int day);    //查询某日是星期几
int main()
{
	int i, year, month, day;
	int k1, k2, k3, k4;    //用于判断输入的数据和操作是否正确,1代表正确,0代表错误
	int a = 1;
	menu();
	do
	{
		printf("请输入你要进行的操作(1-4):");
		scanf_s("%d", &i);
		getchar();
		switch (i)
		{
		case 1:
			printf("请输入你要查询的年份:"); scanf_s("%d", &year);
			for (a; a  12 || month < 1)
				{
					printf("你输入的月份有误,请重新输入!\n");
					printf("月份:");
					scanf_s("%d", &month);
					if (month 12)    k1 = 1;
				}
				else k1 = 0;
			}
			search_month(year, month);
			printf("---------*********************------------\n\n\n");
			break;
		case 3:
			printf("请输入你要查询的日期\n");
			printf("年份:"); scanf_s("%d", &year);
			printf("月份:"); scanf_s("%d", &month);
			k2 = 1;
			while (k2)
			{
				if (month > 12 || month < 1)
				{
					printf("你输入的月份有误,请重新输入!\n");
					printf("月份:");
					scanf_s("%d", &month);
					if (month 12)    k2 = 1;
				}
				else k2 = 0;
			}
			//    printf("%d年%d月有%d天\n",year,month,days_month(year,month));     调试观察输入的日期是否有误,可忽略
			printf("日期:"); scanf_s("%d", &day);
			k3 = 1;
			while (k3)
			{
				if (day > days_month(year, month) || day  days_month(year, month) || day < 1)    k3 = 1;
				}
				else k3 = 0;
			}
			search_someday(year, month, day);
			printf("---------*********************------------\n\n\n"); break;
		case 4:exit(0);
			printf("---------*********************------------\n\n\n"); break;
		default:
			k4 = 1;
			while (k4)
			{
				printf("你输入的数据有误,请重新输入你要进行的操作(1-4):");
				scanf_s("%d", &i);
				if (i 4)    k4 = 1;
				else k4 = 0;
			}
			break;
		}
	} while (i > 0 && i < 5);
	return 0;
}
void menu()
{
	int i = 1;
	printf("\n\n\t\t----------------------------------------\n");
	printf("\t\t|--------------------------------------|\n");
	printf("\t\t|           %d.  输出某年的日历         |\n", i);
	printf("\t\t|           %d.  输出某月的日历         |\n", i + 1);
	printf("\t\t|           %d.  查询某日是星期几       |\n", i + 2);
	printf("\t\t|           %d.  退出系统               |\n", i + 3);
	printf("\t\t|--------------------------------------|\n");
	printf("\t\t----------------------------------------\n\n");
}
int leap(int year)
{
	if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) return 1;
	else return 0;
}
int days_month(int year, int month)
{
	int days_month;
	switch (month)
	{
	case  1:
	case  3:
	case  5:
	case  7:
	case  8:
	case  10:
	case  12: days_month = 31; break;
	case  4:
	case  6:
	case  9:
	case  11:days_month = 30; break;
	case  2:
		if (leap(year) == 1)
		{
			days_month = 29; break;
		}
		else days_month = 28; break;
	}
	return days_month;
}
int someday(int year, int month, int day)
{
	//该函数运用了特殊的计算公式,详细可参见 http://blog.163.com/hexin_mars_blog/blog/static/248215040201571351115699/
	int someday, m, n, i;  //someday表示查询的日子是星期几
	m = year - year / 1000 * 1000;
	n = m - m / 100 * 100 - 1;            //用于获得年份的后两位数
	int days = 0;
	for (i = 1; i < month; i++) days = days + days_month(year, i);
	days = days + day;
	someday = (n + n / 4 - n / 100 + n / 400 + days) % 7;
	return someday;
}
void search_someday(int year, int month, int day)
{
	char weekname[20];
	switch (someday(year, month, day))
	{
	case 0:strcpy_s(weekname, "星期天"); break;
	case 1:strcpy_s(weekname, "星期一"); break;
	case 2:strcpy_s(weekname, "星期二"); break;
	case 3:strcpy_s(weekname, "星期三"); break;
	case 4:strcpy_s(weekname, "星期四"); break;
	case 5:strcpy_s(weekname, "星期五"); break;
	case 6:strcpy_s(weekname, "星期六"); break;
	}
	printf("你所要查询的日期是%s\n", weekname);
}
void search_month(int year, int month)
{
	int i = 0, j, k = 0, m;     //j用于记录某月的第一天是星期几   m用于记录某月的天数  k用于换行提示
	char x[10] = "      ";
	m = days_month(year, month);
	j = someday(year, month, 1);
	//输出某月的日历
	printf("------------------------------------------\n");
	printf("%s\n", str);
	for (; i < j; i++)
	{
		printf("%s", x); k++;
	}
	for (i = 1; i <= m; i++)
	{
		k++;
		if (k % 7 == 0)
		{
			if (i = 10)
			{
				printf("   %d ", i);
				printf("\n");
			}
		}
		else
		{
			if (i = 10)
			{
				printf("   %d ", i);
			}
		}
	}
	printf("\n------------------------------------------\n");
}
void exit()
{
	exit(0);
}


作者:初阳-.-#



[c] 万年历

需要 登录 后方可回复, 如果你还没有账号请 注册新账号