C語言實現(xiàn)萬年歷小功能
更新時間:2020年03月16日 07:52:12 作者:導航者-追夢
這篇文章主要為大家詳細介紹了C語言實現(xiàn)萬年歷小功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C語言實現(xiàn)萬年歷的具體代碼,供大家參考,具體內容如下
一、學了C語言,相信大家都可以做出來。我們要實現(xiàn)的就是用戶輸入年,月,日。然后打印出來。
二、需要用到的知識點
1.for循環(huán)。2.if判斷。3.函數(shù)的調用
如果您們學了圖形庫的話,可以貼圖上去,效果更加好看。我沒有素材,所以,直接用C語言來完成。
三、運行結果

四、我們用C語言代碼實現(xiàn)
/************************************************************************
* 項目名稱:萬年歷
* 項目描述:算法,判斷
* 項目環(huán)境:VS2013
* 生成日期:2020-3-8
* 作者所屬:追夢
*************************************************************************/
#include<conio.h>
#include<stdio.h>
#include<stdlib.h>
int year, month, day;
int run[12] = { 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };//閏年
int ping[12] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };//平年
char weekday[7][10] = { "一", "二", "三", "四", "五", "六", "日" };//星期
void printStar()//打印
{
printf("**************************************************\n");
}
void printBegin()//打印抬頭
{
printf("\t\t萬年歷\t\n");
printStar();
for (int i = 0; i < 7; i++)//打印星期
{
printf("%s\t", weekday[i]);
}
printf("\n");
}
//打印下面的日期,判斷當前年份是平年還是閏年
int leap(int year)
{
if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0)//閏年
return 1;
else if (year % 4 == 0 && year % 100 != 0 && year % 400 == 0)//閏年
return 1;
else
return 0;//平年
}
//計算year離1900年有多少天
int daySum(int year,int month,int day,int run[],int ping[])
{
//參照物1900-1-1-星期一(百度)
int i, sum = 0;
//計算年份天數(shù),閏年+366,平年+365
for( i = 1900; i < year;i++)
{
if (leap(i) == 1)
sum += 366;
else
sum += 365;
}
for (i = 0; i < month-1; i++)//計算月份的天數(shù)
{
if (leap(year) == 1)
sum += run[i];
else
sum += ping[i];
}
return sum;
}
//打印日歷
void printData(int sum, int year, int month)
{
int result, temp, i; //result空格
result = sum % 7;//前面的空格就是余數(shù)---->0-6
//當前月份空余的天數(shù),空格表示
for ( i = 0; i < result; i++)
{
printf("\t");
}
temp = 7 - result;//開始打印1號
if (leap(year) == 1)
{
//數(shù)組下標是從0開始,月份從一號開始i=1
for (i = 1; i <= run[month - 1]; i++)
{
printf("%d\t", i);
if (i == temp || (i - temp) % 7 == 0)//換行
printf("\n");
}
printf("\n");
}
else
{
for (i = 1; i <= ping[month - 1]; i++)
{
printf("%d\t", i);
if (i == temp || (i - temp) % 7 == 0)//換行
printf("\n");
}
printf("\n");
}
}
int main()
{
system("color 2f");//改變黑窗口的顏色
printf("請輸入年 月 日:");
scanf("%d%d%d", &year, &month, &day);
int sum = daySum(year, month, day, run, ping);
printBegin();
printData(sum, year, month);
system("pause");
return 0;
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
圖解C++的STL之stack和queue,輕松理解數(shù)據結構
聚焦?C++?的?STL?中的?stack?和?queue,讓數(shù)據結構變得簡單有趣!?通過圖解的方式,我們將輕松理解這兩個重要的數(shù)據結構,準備好開啟?STL?學習之旅了嗎?讓我們一起探索?stack?和?queue?的奧秘吧!2024-03-03
C語言詳細分析講解內存管理malloc realloc free calloc函數(shù)的使用
C語言內存管理相關的函數(shù)主要有realloc、calloc、malloc、free等,下面這篇文章主要給大家介紹了關于C語言內存管理realloc、calloc、malloc、free函數(shù)的相關資料,需要的朋友可以參考下2022-05-05

