酷代码 AI
菜单

关于日期的结构定义如下: struct DateG{ int yy,mm,dd;}; 编写两个函数,一个计算自公元1年1月1日到指定的日期共经历了多少天。另一个是前一个函数的逆函数:由自公元1年1月1日历经指定的天数后的日期(返回年月日构成的日期)。 函数接口定义: struct DateG days2Date(int x);{//from:{1,1,1} + 100-->{1,4,11} int Days(DateG x);// {2,,4,11} return 465 from{1,1,1} 裁判测试程序样例: struct DateG{ int yy,mm,dd; }; char leapYear(int year);//闰年否 struct DateG _DateG(char *st);{//"1919-9-9"-->{1919,9,9} struct DateG Add(struct DateG x,int y);//{1919,9,9}+50-->{1919,10,29} char* Date2string(struct DateG x);/

```c #include <stdio.h> struct DateG { int yy, mm, dd; }; // 判断是否为闰年 char leapYear(int year) { return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0); } // 每月的天数 int daysInMonth(int year, int month) { int days[] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; if (month == 2 && leapYear(year)) { return 29; } return days[month - 1]; } // 计算自公元1年1月1日到指定的日期共经历了多少天 int Days(struct DateG x) { int totalDays = 0; for (int year = 1; year < x.yy; year++) { totalDays += leapYear(year) ? 366 : 365; } for (int month = 1; month < x.mm; month++) { totalDays += daysInMonth(x.yy, month); } totalDays += x.dd; return totalDays; } // 由自公元1年1月1日历经指定的天数后的日期 struct DateG days2Date(int x) { struct DateG date = {1, 1, 1}; while (x > 0) { int daysInThisYear = leapYear(date.yy) ? 366 : 365; if (x >= daysInThisYear) { x -= daysInThisYear; date.yy++; } else { for (int month = 1; month <= 12; month++) { int daysInThisMonth = daysInMonth(date.yy, month); if (x >= daysInThisMonth) { x -= daysInThisMonth; date.mm++; } else { date.dd = x; x = 0; break; } } } } return date; } // 以下是测试程序提供的测试用函数的模拟实现 struct DateG _DateG(char *st) { struct DateG date; sscanf(st, "%d-%d-%d", &date.yy, &date.mm, &date.dd); return date; } struct DateG Add(struct DateG x, int y) { int days = Days(x) + y; return days2Date(days); } char* Date2string(struct DateG x) { static char str[12]; sprintf(str, "%04d-%02d-%02d", x.yy, x.mm, x.dd); return str; } int main() { char st[12]; scanf("%s", st); struct DateG d1 = _DateG(st), d2 = Add(d1, 60 * 365); printf("[%s]\n", Date2string(d2)); d2 = Add(d2, -1000); printf("[%s]\n", Date2string(d2)); d2 = _DateG("2020-1-23"); printf("%.2f\n", (Days(d2) - Days(d1)) / 365.0); return 0; } ``` 代码说明: 1. `leapYear`函数:用于判断某一年是否为闰年。如果是闰年返回`1`,否则返回`0`。 2. `daysInMonth`函数:根据年份和月份返回该月的天数。如果是闰年的2月,返回29天,否则返回该月正常的天数。 3. `Days`函数:计算从公元1年1月1日到指定日期的总天数。先计算完整年份的天数,再计算当前年份中到指定月份之前的天数,最后加上指定日期的天数。 4. `days2Date`函数:根据从公元1年1月1日开始历经的天数计算对应的日期。先逐年减去完整年份的天数,再逐月减去该月的天数,直到剩余天数小于该月的天数,此时剩余天数即为该月的日期。 5. `_DateG`函数:将输入的字符串(格式为`YYYY-MM-DD`)转换为`DateG`结构体。 6. `Add`函数:将指定日期加上指定的天数,调用`Days`函数计算总天数,再调用`days2Date`函数计算新的日期。 7. `Date2string`函数:将`DateG`结构体转换为字符串(格式为`YYYY-MM-DD`)。 8. `main`函数:读取输入的日期,计算60年后的日期、退休前倒计时1000天的日期以及到2020年1月23日的年龄,并输出结果。 [2025-12-12 13:24:03 | AI问答 | 1203点数解答]

服务商
相关提问
发财导航,免费问AI
实用工具查看更多