KY221 打印日期

KY221 打印日期

⭐️难度:较难(其实还好)

⭐️知识点:模拟

📖题目:

📚题解1:自己做

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>

using namespace std;

void count(int year, int sum) {
    int dayOfMonth[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
    int isLeap;  // 是否是闰年
    if (year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) {  // 闰年二月29天
        dayOfMonth[2] = 29;
    }
    int month = 1;
    int flag = 0;
    for (month = 1;;month++) {
        if (sum > dayOfMonth[month]) {
            sum = sum - dayOfMonth[month];
            flag = 1; // sum超过31天
        }
        else {
            break;
        }
    }
    
    int day = sum;

    printf("%04d-%02d-%02d\n", year, month,day);
}

int main() {
    int year = 0 ;
    int sum = 0;
    while (scanf("%d%d",&year,&sum) != EOF) {
        count(year, sum);
    }
   
    return 0;
}

📚题解2:利用NextDay函数,和 C++中的引用。

cpp 复制代码
 #include <stdio.h>
    using namespace std;
    void NextDay(int &year, int &month, int &day) {
        // & 出现在定义or形参当中 表示引用的意思 出现在其他位置,表示取地址
        // 存储一下 月份和天数的对应关系
        int dayOfMonth[] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };
        int isLeap; // 是否是闰年 
        isLeap = year % 400 == 0 || year % 4 == 0 && year % 100 != 0;
        if (isLeap) {
            dayOfMonth[2] = 29;
        }
        else {
            dayOfMonth[2] = 28;
        }
    
        ++day;
        if (day > dayOfMonth[month]) {
            day = 1;
            ++month;
        }
        if (month > 12) {
            month = 1;
            ++year;
        }
        //printf("NextDay year = %d, month = %d, day = %d\n", year, month, day);
    }
    //int main() {
    //	int year = 1900;
    //	int month = 2;
    //	int day = 28;
    //	NextDay(year, month, day);
    //	printf("main year = %d, month = %d, day = %d\n", year, month, day);
    //	return 0;
    //}
    
    int main() {
        int year, n;
        while (scanf("%d%d", &year, &n) != EOF) {
            int next = 1;
            int curmonth = 1;
            int curday = 1;
            while (1) {
                if (next == n) {
                    break;
                }
                NextDay(year, curmonth, curday);
                ++next;
            }
            printf("%04d-%02d-%02d\n", year, curmonth, curday);
        }
        return 0;
    }

⭕️格式化输出要求:

相关推荐
提笔了无痕1 分钟前
如何用Go实现整套RAG流程
开发语言·后端·golang
(Charon)4 分钟前
【C++ 面试高频基础:指针、引用、const、static、new/delete 总结】
java·开发语言
2601_9618752438 分钟前
法考考试时间安排及科目|时间表|资料已整理
开发语言·c#·inverted-index·suffix-tree·sstable·r-tree·lsm-tree
AI科技星1 小时前
数术工坊第八卷:算力革命
c语言·开发语言·网络·量子计算·agi
geovindu1 小时前
go: Generators Pattern
开发语言·后端·设计模式·golang·生成器模式
码云骑士2 小时前
13-列表append的底层真相(上)-listobject源码中的预分配策略
开发语言·python
.道阻且长.3 小时前
C++ string 操作指南:接口解析
java·c语言·开发语言·c++
蚰蜒螟3 小时前
Java 对象的内存密语:从字段偏移量计算到 Unsafe 访问的完整链路
java·开发语言
星辰_mya3 小时前
CountDownLatch深度解析
java·开发语言·后端·架构
laplaya3 小时前
使用 vcpkg 管理 C++ 项目中的依赖
开发语言·c++