Bootstrap

C语言日历系统源代码

文章目录

  • 🍊自我介绍
  • 🍊源代码


你的点赞评论就是对博主最大的鼓励
当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~


🍊自我介绍

  Hello,大家好,我是小珑也要变强(也是小珑),我是一名准大三学生,现在我来为大家介绍一下有关嵌入式的介绍。


🍊源代码

代码实现以2004-11-14为例,演示结果如下图
在这里插入图片描述

#include <stdio.h>

#define LE_YEAR 1

int isleap(int y)//判断闰年 
{
	if((y % 4 ==0 && y % 100 !=0)||(y % 400 == 0))
		return 1; 
}

int max_day(int y,int m) //返回y年m月的天数
{
	int month[12] = {31,28,31,30,31,30,31,31,30,31,30,31} ;
	int ret = 0;
	
	ret = isleap(y);//是闰年的话,二月要多一天 
	
	if(ret == LE_YEAR)
	{
		month[1] = 29;
	}
	return month[m - 1];//数组从零开始。month[0]储存的是一月份的天数,以此类推,所以返回month[m-1] 
}	


int total_day(int y,int m,int d)//计算输入的year,month,day是该年的第多少天 
{
	int sum = 0; 
	
	int i = 0;
	for(i = 1;i < m;i++)
	{
		sum = sum + max_day(y,i);
	}
	sum = sum + d;
	return sum;
}

int weekday(int y,int m,int d)//计算星期几 
{
	/*
	提示:运用基姆拉尔森林日期计算公式
	W = (d + 2*m + 3*(m+1)/5 + y + y/4 - y/100 + y/400 +1)%7 
	d表示天数,m表示月数,y表示年数,W表示星期几
	W = 0表示是星期日 
	
	如果输入的月份是1月或者2月的话,则要转化为上一年的十三月和十四月来计算 
	eg:
	输入2004-1-10,则应该转换成2003-13-10 
	*/
	
	int W = 0;
	
	if(m == 1 || m == 2)
	{
		m = m + 12;//1+12=13   2+12=14
		y = y - 1;
	}
	W = (d + 2 * m + 3 * (m + 1) / 5 + y + y / 4 - y / 100 + y / 400 +1) % 7 ;
	return W;
}

void display_week(int y,int m,int d)//显示星期几 
{
	int count = 0;
	
	count = weekday(y,m,d);
	
	switch(count)
	{
		case 0:
			printf("%d-%d-%d is Sunday\n",y,m,d);
			break;
		case 1:
			printf("%d-%d-%d is Monday\n",y,m,d);
			break;
		case 2:
			printf("%d-%d-%d is Tuesday\n",y,m,d);
			break;
		case 3:
			printf("%d-%d-%d is Wednesday\n",y,m,d);
			break;
		case 4:
			printf("%d-%d-%d is Thursday\n",y,m,d);
			break;
		case 5:
			printf("%d-%d-%d is Faiday\n",y,m,d);
			break;
		case 6:
			printf("%d-%d-%d is Saturday\n",y,m,d);
			break;
	}
}

void display_month(int y,int m,int d)
{
	//1、获得每个月的1号是星期几
	int W;
	W = weekday(y,m,1);
	
	printf("\n\t\t%d year %d month\n",y,m);
	printf("SUM\tMON\tTUE\tWED\tTHU\tFRI\tSAT\n");
	
	//2、判断这个月有几天
	int day = max_day(y,m); 
	
	//3、本月一号前要输入几个 \t 
	for(int i = 0;i < W;i++)
	{
		printf("\t");
	} 
	//4、控制输出格式
	for(int i = 1;i <= day;i++)
	{
		printf("%d\t",i);
		if((i + W) % 7 == 0)
		{
			printf("\n");
		}
	} 

}

int main()//主函数 
{
	int ret; 
	int year = 0,month = 0,day = 0;
	printf("please input[year month day]:");
	scanf("%d%d%d",&year,&month,&day);
	if(month < 1||month > 12||day < 1||day > 31)
	{
		printf("Input data is error!\n",year,month,day);
		return -1;
	}
	ret = isleap(year);
	
	if(ret == LE_YEAR)
	{
		printf("%d-%d-%d is leap year!\n",year,month,day);
	}
	else
	{
		printf("%ld-%ld-%ld is not leap year!\n");
	}
	
	ret = total_day(year,month,day);
	printf("%d-%d-%d it's the %d day of the year!\n",year,month,day,ret);
	
	display_week(year,month,day);//显示星期几 
	display_month(year,month,day);
	return 0;
}

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;