解题思路:
注意事项:
参考代码:
#include<stdio.h>
#include<math.h>
int month[2][20]={{31,28,31,30,31,30,31,31,30,31,30,31},{31,29,31,30,31,30,31,31,30,31,30,31}};
int leap(int year)
{
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
{
//是闰年
return 1;
}else{
//不是闰年
return 0;
}
}
void calendar(int year,int mon)
{
int i,j;
long sum=0;
int count = 0,flag;
//距离2007年1月1日多少天
for(i=2007;i<year;i++)
{
if(leap(i))
{
sum += 366;
}else{
sum += 365;
}
}
if(leap(year))
{
for(j=0;j<mon-1;j++)
{
sum +=month[1][j];
}
flag=1;
}else{
for(j=0;j<mon-1;j++)
{
sum +=month[0][j];
}
flag=0;
}
printf("---------------------\n Su Mo Tu We Th Fr Sa\n---------------------\n");
count=(sum%7 +1)%7;
for(j=0;j<count*3+1;j++)
{
printf(" ");
}
for(i=1;i<=month[flag][mon-1];i++)
{
printf("%2d",i);
if(count == 6 && i!=month[flag][mon-1])
{
printf("\n");
printf(" ");
}else if(i == month[flag][mon-1]){
printf("\n");
}else{
printf(" ");
}
count=(count+1)%7;
}
printf("---------------------\n");
}
int main()
{
int year,month;
scanf("%d %d",&year,&month);
calendar(year,month);
return 0;
}
0.0分
0 人评分
C语言训练-排序问题<1> (C语言代码)浏览:1351 |
C语言训练-求矩阵的两对角线上的元素之和 (C语言代码)浏览:3394 |
C语言程序设计教程(第三版)课后习题10.7 (C语言代码)浏览:525 |
字符串对比 (C语言代码)浏览:1413 |
C语言程序设计教程(第三版)课后习题5.7 (Java代码)浏览:889 |
printf基础练习2 (有点不明白)浏览:844 |
淘淘的名单 (C语言代码)浏览:1104 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:535 |
矩阵乘方 (C语言代码)浏览:1030 |
C语言训练-亲密数 (C语言描述,反正怎么都能对)浏览:2169 |