A. c語言年歷顯示程序設計
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
char* month[]={"Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nev","Dec"};
char* week[]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"};
int j_leapyear(int year) //定義函數檢測輸入年份是否為閏年
{
if((/*year%400==0*/year%4==0&&year%100!=0)||(year%400==0))
return (1);
// else if(year%4==0&&year%100!=0)
// return (1);
else return 0;
}
int month_day(int year,int month) //檢測該年月份有多少天
{
int mon_day[]={31,28,31,30,31,30,31,31,30,31,30,31};
if(j_leapyear(year)&&month==2)
return 29;
else return (mon_day[month-1]);
}
int j_week(int year,int month,int day) //檢測該天是星期幾
{
int d=0,i; //d表示該天在該年份的累計天數
int w;
/* int month_day[]={31,28,31,30,31,30,31,31,30,31,30,31};
if(j_leapyear(year)==1)
month_day[1]=29;
for(i=0;i<month;i++)
d+=month_day[i];
d=d+day;*/
for(i=1;i<month;i++)
d+=month_day(year,i);
d+=day;
w=(year-1)+(int)(year-1)/4-(int)(year-1)/100+(int)(year-1)/400+d;//網上公式
return ((int)w%7);
}
int allyear(int year) //輸出全年日歷
{
int i,j,b;
printf("\n%d 日歷",year);
for(i=1;i<=12;i++)
{
printf("\n\n\t%s\n",month[i-1]);
// printf(" 7 1 2 3 4 5 6 \n");
printf(" S M T W T F S \n");
b=j_week(year,i,1);
for(j=1;j<=month_day(year,i)+b;j++)
{
if(j<=b)
printf(" ");
else if(j-b<10)
printf("%2d ",j-b);
else printf("%2d ",j-b);
//else printf("%2d ",j-b);
if(j%7==0)
putchar('\n');
}
putchar('\n');
}
return 0;
}
void month_print(int year,int month) //輸入一個年月,輸出這個月的日歷
{
int i,c,d;
c=month_day(year,month);
printf("\n\n %d年%d月日歷\n",year,month);
printf(" S M T W T F S \n");
d=j_week(year,month,1);
for(i=1;i<=c+d;i++)
{
if(i<=d)
printf(" ");
else printf("%2d ",i-d);
if(i%7==0)
putchar('\n');
}
putchar('\n');
}
int jisuan_day(int year,int month,int day,int x,int y,int z) //輸入年月日,輸出距x年y月z日有多少天,星期幾,以及是否是公歷節日
{
int i,a,b,c=0,d=0,days=0,m=0,n=0,t;
a=year>=x?year:x;
b=year<x?year:x;
if(a>b)
{
for(i=b+1;i<a;i++)
c+=j_leapyear(i);
}
else c=0;
if(year!=x)
d=a-b-1;
else d=0;
m=365*d+c;
if(year<x)
{
for(i=month;i<=12;i++)
n+=month_day(year,i);
days=m+n+z-day;
}
else if(year>x)
{
for(i=y;i<=12;i++)
n+=month_day(x,i);
for(i=1;i<month;i++)
n+=month_day(year,i);
days=m+n+day-z;
}
else
{
for(i=month>=y?y:month;i<(month>=y?month:y);i++)
n+=month_day(x,i);
days=abs(day-z)+n; //輸出距離y月z日有多少天
}
printf("這天離%d年%d月%d號有%d天\n",x,y,z,days);
t=j_week(year,month,day);
if(t==0) //輸出星期幾
printf("這天星期日");
else if(t==1)
printf("這天星期一");
else if(t==2)
printf("這天星期二");
else if(t==3)
printf("這天星期三");
else if(t==4)
printf("這天星期四");
else if(t==5)
printf("這天星期五");
else if(t==6)
printf("這天星期六");
putchar('\n');
if(month==1&&day==1)
printf("這天是元旦節");
else if(month==2&&day==14)
printf("這天是情人節");
else if(month==3&&day==8)
printf("這天是婦女節");
else if(month==3&&day==12)
printf("這天是植樹節");
else if(month==4&&day==1)
printf("這天是愚人節");
else if(month==4&&day==4)
printf("這天是清明節");
else if(month==5&&day==1)
printf("這天是勞動節");
else if(month==6&&day==1)
printf("這天是兒童節");
else if(month==8&&day==1)
printf("這天是建軍節");
else if(month==9&&day==10)
printf("這天是教師節");
else if(month==10&&day==1)
printf("這天是國慶節");
else if(month==12&&day==25)
printf("這天是聖誕節");
else printf("這天不是特殊節日");
putchar('\n');
return days;
}
void fish_or_net(int year,int month,int day) //判斷是打魚還是曬網
{
int q;
int i,a,b,c=0,d=0,days=0,m=0,n=0;
a=year>=1990?year:1990;
b=year<1990?year:1990;
if(a>b)
{
for(i=b+1;i<a;i++)
c+=j_leapyear(i);
}
else c=0;
if(year!=1990)
d=a-b-1;
else d=0;
m=365*d+c;
if(year<1990)
{
for(i=month;i<=12;i++)
n+=month_day(year,i);
days=m+n+1-day;
}
else if(year>1990)
{
for(i=1;i<=12;i++)
n+=month_day(1990,i);
for(i=1;i<month;i++)
n+=month_day(year,i);
days=m+n+day-1;
}
else
{
for(i=month>=1?1:month;i<(month>=1?month:1);i++)
n+=month_day(1990,i);
days=abs(day-1)+n; //先確定這天離1990年1月1日有多少天
}
q=days%5+1;
if(q==1||q==2||q==3) //判斷打魚還是曬網
printf("漁人今天打魚");
else printf("漁人今天曬網");
putchar('\n');
}
/*int main() //這部分內容用來校檢
{
int j_leapyear(int year);
int month_day(int year,int month);
int j_week(int year,int month,int day);
int allyear(int year);
void month_print(int year,int month);
int jisuan_day(int year,int month,int day,int x,int y,int z);
void fish_or_net(int year,int month,int day);
int x,y,z,year,month,day;
// allyear(2015);
//month_print(2016,12);
printf("請輸入今天的日期(按年,月,日輸入,如2016,1,14表示2016年1月14日):");
scanf("%d,%d,%d",&x,&y,&z);
printf("\n請隨便輸入一個日期,格式同上:");
scanf("%d,%d,%d",&year,&month,&day);
jisuan_day(year,month,day,x,y,z);
// fish_or_net(x,y,z);
return 0;
} // 這部分內容是用來檢測上述函數是否出錯的
*/
int main()
{
int j_leapyear(int year);
int month_day(int year,int month);
int j_week(int year,int month,int day);
int allyear(int year);
void month_print(int year,int month);
int jisuan_day(int year,int month,int day,int x,int y,int z);
void fish_or_net(int year,int month,int day); //函數聲明
int option,year,month,day,x,y,z;
char ny;
system("color 1f");
while (1)
{
printf("\n\n\t 歡迎來到由...編寫的程序\n\n");
printf(" 請選擇您需要的服務,輸入編號回車結束\n");
printf(" 1.輸入一個年份,輸出該年的日歷\n");
printf(" 2.輸入年月,輸出這個月的日歷。\n");
printf(" 3.輸入年月日,輸出據今天還有多久,星期幾,是否是公歷節日。\n");
printf(" 4.某人自1990年1月1日開始打魚,「三天打魚,兩天曬網」,輸入一個1990年以後的日期,輸出他這一天是打魚還是曬網。\n");
printf(" 5.退出\n");
scanf("%d",&option);
switch(option) //switch分支結構
{
case 1:
while(1) //while循環,後面的1是常數,表示一直到break才結束循環
{
printf("請輸入一個年份:");
scanf("%d",&year);
allyear(year);
printf("你想繼續查詢日歷么?(y表示繼續,n表示結束)");
scanf("%c",&ny);
if(ny=='n')
break;
}
break;
case 2:
while (1)
{
printf("輸入年月:");
scanf("%d,%d",&year,&month);
month_print(year,month);
printf("你想繼續查詢日歷么?(y表示繼續,n表示結束):");
scanf("%c",&ny);
if(ny=='n')
break;
}
break;
case 3:
while (1)
{
printf("輸入年月日:");
scanf("%d,%d,%d",&year,&month,&day);
printf("請輸入今天的日期:");
scanf("%d,%d,%d",&x,&y,&z);
jisuan_day(year,month,day,x,y,z);
printf("你想繼續查詢么?(y表示繼續,n表示結束):");
scanf("%c",&ny);
if(ny=='n')
break;
}
break;
case 4:
while (1)
{
printf("輸入1990年1月1日以後的一個日期:");
scanf("%d,%d,%d",&year,&month,&day);
fish_or_net(year,month,day);
printf("你想繼續查詢漁人是打魚還是曬網么?(y表示繼續,n表示結束):");
scanf("%c",&ny);
if(ny=='n')
break;
}
break;
case 5:
while (1)
{
printf("確認么?y表示是的,n表示不是");
scanf("%c",&ny);
if(ny=='y')
exit(1); //表示退出程序
else if(ny=='n')
break;
}
break;
default:printf("對不起,暫時沒有這個服務");
break;
}
}
return 0;
}
B. 求C語言程序(萬年歷)講解
你的代碼一共有如下幾個問題:
1.
你使用scanf("%c",&a)來接收用戶輸入的一個字元時,會將回車符也接收下來。C語言在處理時,會將用戶輸入放在鍵盤緩沖區,使用scanf來接收%c時,編譯器從鍵盤緩沖區讀取一個char字元,但是並不清空後面的字元,所以導致下一次scanf("%c",&a)時,將剩下的回車符先給讀進來,並進行處理了。
要解決這個問題,可以使用getch()或者getche()函數。
但是:
getch()介面,接收字元後不會將字元回顯到顯示器,所以用戶看不到自己輸入的字元。
而getche()介面就沒有這個問題,所以應該使用getche()。
2.
循環計數錯誤,多循環一次。
這個你仔細推算一下就出來了。
一般解決這種問題的話,使用do/while循環較多,因為do/while循環可讀性好一些。
以下是改過以後的代碼,已經編譯運行確認:
#include
<stdio.h>
#include
<conio.h>
main()
{
char
a;
int
i=3;
a=getche();//這里使用getche()來接收用戶輸入,既可以回顯,也不會接收回車
do
{
i--;//將i--放在這里,防止出現可以輸入4次的情況
if(a!='b'&&i>0)
{
printf("錯誤\n");
a=getche();//這里使用getche()來接收用戶輸入,既可以回顯,也不會接收回車
}
else
break;
}while(1);
if(a=='b')
{
printf("正確");
}
else
getch();
}
C. 用C語言實現萬年歷
#include <stdio.h>
#include <conio.h>
#include <time.h>
#include <stdlib.h>
long Year;
int date[12][6][7];
int day_tbl[ ][12]={{31,28,31,30,31,30,31,31,30,31,30,31},
{31,29,31,30,31,30,31,31,30,31,30,31}};//每月最後一天
char *str[]={"一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月"};
void nian(long year,FILE *fp)
{
int i,j,n=0,t;
char s[5][23];//把數字圖形看作一個二維數組
void fyear(int t,int n,char s[5][23]);
for(i=0;i<5;i++){
for(j=0;j<23;j++){
if(((i==1)||(i==3))&&((j>=1&&j<=3)||(j>=7&&j<=9)||(j>=13&&j<=15)||(j>=19&&j<=21)))
s[i][j]=' ';
else if((j==5)||(j==11)||(j==17))
s[i][j]=' ';
else
s[i][j]='*';
}//判斷『*』的位置
}
do{
t=year%10;
year=year/10;
fyear(t,n,s);
n++;
}while(year!=0);
if(n<4){
for(i=0;i<5;i++){
for(j=0;j<24-6*n;j++)
s[i][j]=' ';
}
}
for(i=0;i<5;i++){
printf(" ");
fprintf(fp,"%s"," ");
for(j=0;j<23;j++){
printf("%c",s[i][j]);
fprintf(fp,"%c",s[i][j]);
}
printf("\n");
fprintf(fp,"\n");
}
}//用『*』顯示年份
void fyear(int t,int n,char s[5][23])
{
int i,j;
switch(t){
case 0:
for(j=19-6*n;j<22-6*n;j++)
s[2][j]=' ';
break;
case 1:
for(i=0;i<5;i++){
for(j=18-6*n;j<22-6*n;j++)
s[i][j]=' ';
}
break;
case 2:
s[1][18-6*n]=' ';
s[3][22-6*n]=' ';
break;
case 3:
s[1][18-6*n]=' ';
s[3][18-6*n]=' ';
break;
case 4:
for(j=19-6*n;j<22-6*n;j++){
s[0][j]=' ';
s[4][j]=' ';
}
s[3][18-6*n]=' ';
s[4][18-6*n]=' ';
break;
case 5:
s[1][22-6*n]=' ';
s[3][18-6*n]=' ';
break;
case 6:
s[1][22-6*n]=' ';
break;
case 7:
for(i=1;i<5;i++){
for(j=18-6*n;j<22-6*n;j++)
s[i][j]=' ';
}
break;
case 8:
break;
case 9:
s[3][18-6*n]=' ';
break;
}
}//判斷圖形數字里的空格
long int f(long year,int month)
{
if(month<3) return year-1;
else return year;
}
long int g(int month)
{
if(month<3) return month+13;
else return month+1;
}
long int n(int year,int month,int day)
{
return 1461L*f(year,month)/4+153L*g(month)/5+day;
}
int w(int year,int month,int day)
{
return(int)((n(year,month,day)%7-621049L%7+7)%7);
}//計算查詢日期所處位置
void yueli(int m,FILE *fp)
{
struct tm *local;
long t;
long i,sw,wd,day,leap,k,j;
char title[]=" 日 一 二 三 四 五 六";
void rili(long year,FILE *fp);
time(&t);
local = localtime(&t);
local->tm_year = local->tm_year + 1900;
local->tm_mon ++;
Year=local->tm_year;
if(m==1){
printf("\t\t\t %s\n",str[local->tm_mon-1]);
fprintf(fp,"\t\t\t %s\n",str[local->tm_mon]);
printf("\t\t ___________________________\n");
fprintf(fp,"\t\t ___________________________\n");
printf("\t\t %s\n",title);
fprintf(fp,"\t\t %s\n",title);
sw=w(local->tm_year,local->tm_mon,1);
leap=local->tm_year%4==0&&local->tm_year%100||local->tm_year%400==0;
for(i=0;i<12;i++)
for(j=0;j<6;j++)
for(k=0;k<7;k++)
date[i][j][k]=0;
for(wd=0,day=1;day<=day_tbl[leap][local->tm_mon-1];day++)
{
date[local->tm_mon][wd][sw]=day;
sw=++sw%7;//每星期七天,以0至6計數
if(sw==0) wd++;//日期表每七天一行,星期天開始新的一行
}
for(j=0;j<6;j++){
printf("\t\t ");
fprintf(fp,"\t\t ");
for(k=0;k<7;k++)
if(date[local->tm_mon][j][k]){
printf("%3d ",date[local->tm_mon][j][k]);
fprintf(fp,"%3d ",date[local->tm_mon][j][k]);
}
else{
printf(" ");
fprintf(fp,"%s"," ");
}
printf("\n");
fprintf(fp,"\n");
}
printf("\t\t 今天是: %ld年%ld月%ld日,",local->tm_year,local->tm_mon,local->tm_mday);
fprintf(fp,"\t\t 今天是: %ld年%ld月%ld日,",local->tm_year,local->tm_mon,local->tm_mday);
switch(local->tm_wday){
case 0:printf("星期日\n");fprintf(fp,"星期日\n");break;
case 1:printf("星期一\n");fprintf(fp,"星期一\n");break;
case 2:printf("星期二\n");fprintf(fp,"星期二\n");break;
case 3:printf("星期三\n");fprintf(fp,"星期三\n");break;
case 4:printf("星期四\n");fprintf(fp,"星期四\n");break;
case 5:printf("星期五\n");fprintf(fp,"星期五\n");break;
case 6:printf("星期六\n");fprintf(fp,"星期六\n");break;
default:printf("error\n");
}
printf(" \t\t 當前時間是: %ld時%ld分%ld秒\n",local->tm_hour,local->tm_min,local->tm_sec);
fprintf(fp," \t\t 當前時間是: %ld時%ld分%ld秒\n",local->tm_hour,local->tm_min,local->tm_sec);
}//顯示當前系統時間
if(m==2)
rili(local->tm_year,fp);
}
void rili(long year,FILE *fp)
{ int sw,leap,i,j,k,wd,day;
char title[]=" 日 一 二 三 四 五 六";
sw=w(year,1,1);
leap=year%4==0&&year%100||year%400==0;//判閏年
for(i=0;i<12;i++)
for(j=0;j<6;j++)
for(k=0;k<7;k++)
date[i][j][k]=0;//日期表置0
nian(year,fp);
for(i=0;i<12;i++)//一年十二個月
for(wd=0,day=1;day<=day_tbl[leap][i];day++)
{//將第i+1月的日期填入日期表
date[i][wd][sw]=day;
sw=++sw%7;//每星期七天,以0至6計數
if(sw==0) wd++;//日期表每七天一行,星期天開始新的一行
}
for(i=0;i<11;i+=2)
{//先測算第i+1月和第i+2月的最大星期數
// for(wd=0,k=0;k<7;k++)//日期表的第六行有日期,則wd!=0
// wd+=date[i][5][k]+date[i+2][5][k];
// wd=6;
printf("\t\t%s\t\t\t\t%s\n",str[i],str[i+1]);
fprintf(fp,"\t\t%s\t\t\t\t%s\n",str[i],str[i+1]);
printf(" ___________________________ ___________________________\n");
fprintf(fp," ___________________________ ___________________________\n");
printf(" %s %s \n",title,title);
fprintf(fp," %s %s \n",title,title);
for(j=0;j<6;j++)
{
printf(" ");//輸出四個空白符
//左欄為第i+1月,右欄為第i+2月
fprintf(fp," ");
for(k=0;k<7;k++)
if(date[i][j][k]){
printf("%4d",date[i][j][k]);
fprintf(fp,"%4d",date[i][j][k]);
}
else{
printf(" ");
fprintf(fp," ");
}
printf(" ");//輸出十個空白符
fprintf(fp," ");
for(k=0;k<7;k++)
if(date[i+1][j][k]){
printf("%4d",date[i+1][j][k]);
fprintf(fp,"%4d",date[i+1][j][k]);
}
else{
printf(" ");
fprintf(fp," ");
}
printf(" \n");
fprintf(fp," \n");
}
//鍵入回車輸出下一行的日歷
}
}
void main()
{
FILE *fp;
int choice;
if((fp=fopen("E:\\out1.txt","w"))==NULL){
printf("open error!\n");
exit(0);
}
yueli(1,fp);
while(1){
printf("歡迎使用本程序!請按提示選擇\n");
printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
printf("按[1]查看當天信息和本月月歷\n");
printf("按[2]查看當年日歷\n");
printf("按[3]查看某年日歷\n");
printf("按[4]查看下一年日歷\n");
printf("按[5]查看上一年日歷\n");
printf("按[0]退出\n");
printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
printf("輸入你的選擇並按回車結束:");
scanf("%d",&choice);
switch(choice){
case 1:yueli(1,fp);break;
case 2:yueli(2,fp);break;
case 3:
printf("請輸入你要查詢的年份: ");//輸入年
scanf("%d",&Year);
rili(Year,fp);
break;
case 4:rili(++Year,fp);break;
case 5:rili(--Year,fp);break;
case 0:printf("感謝您的使用,再見!\n");return;
}
}
fclose(fp);
return;
}
D. 用C語言怎麼編寫這個萬年歷
核心演算法:星期(0~6)=(年份系數+月份系數+日期)%7;
其中,年份系數我以2007年做參照,已知2007年,年份系數是0,往前往後分別是遞減和遞增。增減規律:非閏年為±1,閏年1~2月-2或+1,閏年3~12月+2或者-1。
其中,12個月份系數對應:0,3,3,6,1,4,6,2,5,0,3,5。
根據以上規律,只要利用循環,就可以的到對應系數和星期。
日歷實現翻頁功能,按鍵盤左右方向鍵可以翻譯查看當年其他月份,按向上方向鍵可以返回菜單。
下面是代碼:
#include <stdio.h>
#include <malloc.h>
#include <string.h>
#include <conio.h>
#include <math.h>
#include <time.h>
#define XY 2007
#define X07 0//以2007年年系數0做參照
int isLeapYear(int year);//判斷是否是閏年,是返回1,否返回0
int addyx(int yx,int n);//年系數自增,0~6,n:自增的跨度,返回自增後的年系數
int getYX(int year,int month);//獲得年系數0~6
int getMX(int month);//獲得月系數
int getWeek(int yx,int mx,int day);//通過年月系數(yx:年系數;mx:月系數)及日期獲取星期
char *getStrWeek(int yx,int mx,int day);//通過年月系數(yx:年系數;mx:月系數)及日期獲取星期對應的中文字元串
int getMaxDay(int year,int month);//通過年月獲取當月最大天數
void prCalendar(int year,int month);//列印日歷
int showMeun();//列印主菜單
int getDuration(int year,int month,int day);//通過日期獲取距今天數
int calendar[6][7];
int main()
{
//int year,month,day,yx,mx;
while(1)
{
if(!showMeun())
break;
}
return 0;
}
int showMeun()//列印主菜單
{
int n,year,month,day,yx,mx;
while(1)
{
system("cls");
printf("1、輸入年份,顯示該年每個月的日歷 ");
printf("2、輸入年月,顯示該月的天數 ");
printf("3、輸入日期,顯示距離今天的天數 ");
printf("4、輸入日期,查詢這一天是星期幾 ");
printf("0、結束程序 ");
n=-1,year=0,month=0,day=0;
while(n<0 || n>4)
{
printf("請輸入選擇的菜單序號:");
scanf("%d",&n);
}
switch(n)
{
case 1:while(year<=0 || year>9999)
printf("請輸入年份:"),scanf("%d",&year);
prCalendar(year,1);
break;
case 2:while(year<=0 || year>9999 || month<=0 || month>12)
printf("請輸入年份及月份:"),scanf("%d%d",&year,&month);
printf("%4d年%2d月共有%d天 按任意鍵繼續。。。。。。 ",year,month,getMaxDay(year,month)),getch();
break;
case 3:while(year<=0 || year>9999 || month<=0 || month>12 || day<0 || day>getMaxDay(year,month))
printf("請輸入日期:"),scanf("%d%d%d",&year,&month,&day);
printf("距離今日有%d天 按任意鍵繼續。。。。。。 ",getDuration(year,month,day)),getch();
break;
case 4:while(year<=0 || year>9999 || month<=0 || month>12 || day<0 || day>getMaxDay(year,month))
printf("請輸入日期:"),scanf("%d%d%d",&year,&month,&day);
yx=getYX(year,month);
mx=getMX(month);
printf("%4d年%2d月%2d日是%s 按任意鍵繼續。。。。。。 ",year,month,day,getStrWeek(yx,mx,day)),getch();
break;
case 0:return 0;
}
}
return n;
}
void prCalendar(int year,int month)//列印日歷
{
char c1,c2;
int i,j,*p=NULL,yx,mx,cnt,w,maxDay;
while(1)
{
p=&calendar[0][0];
yx=getYX(year,month),mx=getMX(month);
cnt=0,w=getWeek(yx,mx,1);
maxDay=getMaxDay(year,month);
for(i=0;i<6;i++)
for(j=0;j<7;j++)
{
if(cnt<w)
p++,cnt++;
calendar[i][j]=0;
}
for(i=1;i<=maxDay;i++)
*p=i,p++;
system("cls");
printf(" %4d 年%2d月 ",year,month);
printf("日 一 二 三 四 五 六 ");
for(i=0;i<6;i++,printf(" "))
for(j=0;j<7;j++)
if(calendar[i][j]==0)
printf(" ");
else
printf("%2d ",calendar[i][j]);
printf("<- 按方向鍵向左或向右翻頁 -> ");
printf(" 按向上方向鍵返回主菜單 ");
c1=getch();
c2=getch();
if(c1==-32 && c2==75)//左鍵
{
if(month==1)
month=12;
else
month--;
}
if(c1==-32 && c2==77)//右鍵
{
if(month==12)
month=1;
else
month++;
}
if(c1==-32 && c2==72)//上鍵
{
showMeun();
break;
}
}
}
int getDuration(int year,int month,int day)//通過日期獲取距今天數
{
int i,y,m,d,sum=0,sum2=0,minY,maxY,minM,maxM,minD,maxD;
time_t tt;
struct tm *tmp;
time(&tt);
tmp=localtime(&tt);
y=1900+tmp->tm_year,m=1+tmp->tm_mon,d=tmp->tm_mday;//獲取當前日期的年月日
if(year<y)
minY=year,maxY=y,minM=month,maxM=m,minD=day,maxD=d;
if(year>y)
minY=y,maxY=year,minM=m,maxM=month,minD=d,maxD=day;
if(year!=y)
{
for(i=minY;i<maxY;i++)//按相差年份累加(不包含右端最大年份)
if(isLeapYear(i))
sum+=366;//閏年
else
sum+=365;
for(i=1;i<minM;i++)//扣除左端年份已過月份對應天數
sum-=getMaxDay(minY,i);
sum-=minD;//扣除左端當月已過天數
for(i=1;i<maxM;i++)//累加右端最大年份已過月份對應天數(不包含最大年份當月)
sum+=getMaxDay(maxY,i);
sum+=maxD;//累加右端當月已過天數
}
else//如果年份相同,累加兩邊一年內已過天數,求差值
{
for(i=1;i<month;i++)
sum+=getMaxDay(month,i);
sum+=day;
for(i=1;i<m;i++)
sum2+=getMaxDay(m,i);
sum2+=d;
return abs(sum2-sum);
}
return sum;
}
int getMaxDay(int year,int month)//通過年月獲取當月最大天數
{
int days[12]={31,28,31,30,31,30,31,31,30,31,30,31};
if(isLeapYear(year) && month==2)
return days[month-1]+1;
return days[month-1];
}
char *getStrWeek(int yx,int mx,int day)//通過年月系數(yx:年系數;mx:月系數)及日期獲取星期對應的中文字元串
{
int w;
static char week[7];
memset(week,0,7);
strcpy(week,"星期");
w=getWeek(yx,mx,day);
switch(w)
{
case 0:strcat(week,"日");break;
case 1:strcat(week,"一");break;
case 2:strcat(week,"二");break;
case 3:strcat(week,"三");break;
case 4:strcat(week,"四");break;
case 5:strcat(week,"五");break;
case 6:strcat(week,"六");break;
}
return week;
}
int getWeek(int yx,int mx,int day)//通過年月系數(yx:年系數;mx:月系數)及日期獲取星期對應的數值0~6
{
return (yx+mx+day)%7;
}
int getMX(int month)//獲得月系數
{
int xmonth[12]={0,3,3,6,1,4,6,2,5,0,3,5};//月系數:1-12月,每月的系數。
return xmonth[month-1];
}
int getYX(int year,int month)//獲得年系數0~6
{
int yx=0,nyear=XY,isly,flag;
if(nyear==year)
return 0;
if(nyear<year)
flag=0,nyear++;
else
flag=1,nyear--;
while(1)
{
isly=isLeapYear(nyear);
if(!isly){//非閏年年系數累加1
if(!flag)
yx=addyx(yx,1);
else
yx=addyx(yx,-1);
}
if(isly && month>=1 && month<=2){//閏年1~2月年系數累加1,3`12月年系數累加2
if(!flag)
yx=addyx(yx,1);
else
yx=addyx(yx,-2);
}
else if(isly && month>=3 && month<=12){
if(!flag)
yx=addyx(yx,2);
else
yx=addyx(yx,-1);
}
if(nyear==year)
break;
if(!flag && nyear<year)
nyear++;
if(flag && nyear>year)
nyear--;
}
return yx;
}
int addyx(int yx,int n)//年系數自增,0~6,n:自增的跨度,返回自增後的年系數
{
if(n>0)
{
if(yx+n<=6)
return yx+n;
if(yx+n>6)
return yx+n-7;
}
if(n<0)
{
if(yx+n>=0)
return yx+n;
if(yx+n<0)
return yx+n+7;
}
return -1;
}
int isLeapYear(int year)//判斷是否是閏年,是返回1,否返回0
{
if((year%4==0 && year%100!=0)||(year%400==0))
return 1;
return 0;
}
E. c語言年歷編程
#include<stdio.h>
staticintyear;
staticintweekDay;
boolisLeapYear(inty)//判斷是否是閏年
{
return(y%4==0&&y%100!=0||y%400==0);//閏年的條件就是年份同時能被4和100整除或
//者能被400整除
}
longfirstDayOfYear(inty)//求出輸入的那年第一天是星期幾
{
longn;
n=y*365;
for(inti=1;i<y;i++)
if(isLeapYear(i))
n+=1;
returnn%=7;
}
voidprintHead(intm)//列印每個月的標題
{
if(m<10)
printf("%d月日一二三四五六 ",m);
else
printf("%d月日一二三四五六 ",m);
printf("");
for(inti=0;i<weekDay;i++)
printf("");
}
intdaysOfMonth(intm)//判斷每個月有多少天
{
switch(m)
{
case1:
case3:
case5:
case7:
case8:
case10:
case12:return31;
case4:
case6:
case9:
case11:return30;
case2:if(isLeapYear(year))
return29;
else
return28;
}
return0;
}
voidprintMonth(intm)//列印每月的日歷
{
printHead(m);
intdays=daysOfMonth(m);
for(inti=1;i<=days;i++)
{
if(i<10)
printf("%d",i);
else
printf("%d",i);
weekDay=(weekDay+1)%7;
if(weekDay==0)
{
printf(" ");
printf("");
}
}
}
voidmain()//主程序入口,接收輸入的年份,調用函數列印日歷
{
inty;
printf("請輸入年份:");
scanf("%d",&y);
year=y;
if(year<1)
{
printf("輸入年份不能小於1 ");
return;
}
weekDay=(int)firstDayOfYear(year);
printf("%d年 ",year);
printf("======================================== ");
for(inti=1;i<=12;i++)
{
printf(" ");
printMonth(i);
printf(" ");
}
}
可以顯示公元1世紀以後的所有年份的日歷,第2和第3問其實都包含在第1問里,程序看懂了自然也就會了(話說為什麼不能上傳附件?)
F. 用C語言怎麼編寫萬年歷
C語言編寫萬年歷的源代碼如下:
#include <stdio.h>
int week(int y,int m,int d);
int main()
{
char wk[7][3] = {{"天"},{"一"},{"二"},{"三"},{"四"},{"五"},{"六"}};
int year, month, day, w;
scanf("%d %d %d", &year, &month, &day);
w = week(year, month, day);
printf("%d年%d月%d日 星期%s", year, month, day, wk[w]);
}
int week(int y,int m,int d)
{
static int r[13]={0,0,3,3,6,1,4,6,2,5,0,3,5};
int c,w;
y %= 400;
if ((y==0||y%4==0&&y%100!=0)&&m<3)
c = 5;
else
c = 6;
w = (y+y/4-y/100+r[m]+d+c)%7;
return w;
}
(6)c語言年歷思路擴展閱讀
電子時鍾C語言版的源代碼如下:
#include<stdio.h>
#include<time.h>
#include<string.h>
int main()
{
char str[50];
time_t t;
struct tm *nt;
while(1)
{
system("cls");//清屏函數
t=time(NULL);
nt=localtime(&t);
strftime(str,50,"%Y-%m-%d %H:%M:%S 「,nt);
printf("現在時刻:%s ",str);
}
getch();
return 0;
}