/* 该程序在vc中调试运行通过. */
#include <stdio.h> #include<malloc.h> #include<string.h> #include<stdlib.h>
typedef strUCt { unsigned char day; unsigned char month; unsigned short year;
}T_MFW_DATE; typedef struct { T_MFW_DATE date; /*记录的日期*/ }t_cldrecord;
typedef struct { T_MFW_DATE today_date; /*在程序中没有作用*/ T_MFW_DATE cursor_date; int days_map[6][7]; /*日期地图*/ }t_cldmain_data;
t_cldmain_data *cldmain_data;
void cldmain_get_days_map(void);
void main(void) { int i,j; cldmain_data = (t_cldmain_data*)malloc(sizeof(t_cldmain_data)); cldmain_data->cursor_date.day = 20; while(1) { char buf[20]; char *p; memset(buf,0,20);
printf("year month:"); gets(buf); if(buf[0] == 'q')break;
cldmain_data->cursor_date.year = strtod(buf,&p); p ++; cldmain_data->cursor_date.month = strtod(p,&p);
printf("year %d
month %d
",(cldmain_data->cursor_date.year),(cldmain_data->cursor_date.month)); cldmain_get_days_map(); printf(" mo tu w th fr sa su
"); for(j = 0; j < 6; j ++) { printf(" "); for(i = 0; i < 7; i ++) { printf("%i ",cldmain_data->days_map[j][i]); } printf("
"); } } //getchar(); } /* 检查日期是否合法 合法返回1,否则返回0 */ int check_date(T_MFW_DATE date) { char month_days[] = ;
/*大于2000年,小于2100年,月份合法*/ if(date.year < 2000 date.year >= 2100 date.month < 1 date.month > 12) { return 0; }
/*day合法*/ if(date.day < 1)return 0; if(date.day > month_days[date.month - 1])return 0; if(date.month == 2) { if(date.year % 4 != 0) { if(date.day == 29)return 0; } } return 1; } /* 功能:得到每个月第一天是星期几
星期 一 二 三 四 五 六 日 返回值:1 2 3 4 5 6 7 假如返回为0,则出错 */ int get_weekday_of_month(T_MFW_DATE cursor_date) { int day; /*参照1997年1月1日,参数cursor_date从2000年1月1日到2099年1月1日*/ //char month_days[] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; int this_year_days[] ={ 0, 31, 59, 90, 120, 151,181, 212, 243, 273, 304, 334}; int cursor_year_days = this_year_days[cursor_date.month - 1] + (cursor_date.day = 1); int comp_days = (cursor_date.year - 1997)*365 + cursor_year_days; int i = (cursor_date.year - 1997)/4; comp_days = comp_days + i * 1; if(cursor_date.month > 2) { if( cursor_date.year % 4 == 0 ) { comp_days += 1; } } if(cursor_date.day > 2098)return 0; day = comp_days % 7; /*1997年1月1日是星期三*/ day = (day + 2) % 7; if(day == 0)day = 7; return day; }
/* 根据参数的值,得到该年该月有多少天. 返回值:该月的天数 */ int count_days_of_month(T_MFW_DATE cursor_date) { char month_days[] = ; unsigned char day = cldmain_data->cursor_date.day; unsigned char month = cldmain_data->cursor_date.month; unsigned short year = cldmain_data->cursor_date.year; if(month != 2) { return month_days[month -1]; } else { if(year%4 != 0) { return 28; } if(year%4 == 0) { if(year%100 == 0) { if(year %400 == 0) { return 29; } return 28; } return 29; } } } /* 得到日期地图,保存到全局结构变量cldmain_data的成员数组变量days_map中. */ void cldmain_get_days_map(void) { int i; int day;
T_MFW_DATE cursor_date = cldmain_data->cursor_date; int *map_p = cldmain_data->days_map[0]; int days_count; int weekday;
for(i = 0; i < 6*7; i++) { map_p[i] = 0; }
if(check_date(cldmain_data->cursor_date) == 0)return;
days_count = count_days_of_month(cldmain_data->cursor_date); weekday = get_weekday_of_month(cldmain_data->cursor_date);
day = 1; for(i = weekday-1; i < days_count + weekday - 1; i++) { map_p[i] = day; day ++; } }
|