蓝桥杯:日期问题(我的绝望题)

2024-04-24 14:52
文章标签 问题 蓝桥 日期 绝望

本文主要是介绍蓝桥杯:日期问题(我的绝望题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🎁个人主页:我们的五年

🔍系列专栏:每日一练

🌷追光的人,终会万丈光芒

目录

 前言:

 🌷1.问题描述:

 1.问题描述:

2.输入格式:

3.输出格式:

🌷 2.问题分析:

 🌷 3.最终代码:

总结:


 

 前言:

这是学校组织比赛时的一道模拟题,写完这道题我才发现我是真正的菜鸟,希望通过这道题来对自己进行一个反省。

我是菜鸟,所以我多练!

 🌷1.问题描述:

 1.问题描述:

小明正在整理一批历史文献。这些历史文献中出现了很多日期。

小明知道这些日期都在1960年1月1日至2059年12月31日。

令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日的,有采用月/日/年的,还有采用日/月/年的。

更加麻烦的是,年份也都省略了前两位,使得文献上的一个日期,存在很多可能的日期与其对应。

比如02/03/04,可能是2002年03月04日、2004年02月03日或2004年03月02日。

给出一个文献上的日期,你能帮助小明判断有哪些可能的日期对其对应吗?

2.输入格式:

一个日期,格式是”AA/BB/CC”。

即每个’/’隔开的部分由两个 0-9 之间的数字(不一定相同)组成。

3.输出格式:

输出若干个不相同的日期,每个日期一行,格式是”yyyy-MM-dd”。

多个日期按从早到晚排列。

4.输入和输出样例: 

 

🌷 2.问题分析:

 

 mian函数:

int main()
{
    int a, b, c;
    scanf("%d/%d/%d", &a, &b, &c);

    judge(a, b, c);        //可能为年,月,日
    judge(c, a, b);        //可能为月,日,年
    judge(c, b, a);        //可能为日,月,年

    qsort(data, k, sizeof(data[0]), cmp);

    for (int i = 0; i < k; i++)
        printf("%d-%02d-%02d\n", data[i].year, data[i].month, data[i].day);
    return 0;
}

 ⛳️1.对于日期类型的问题我们可以创建结构体来解题,本题三种情况,我们只需创建结构体数组,数组大小为3,且为全局变量。

typedef struct DATA {
    int year;
    int month;
    int day;
}DATA;
DATA data[3];

 ⛳️2.对于年份的问题我们也要去考虑闰年的情况

int is_leap_year(int n)
{
    if (n % 4 == 0 && n % 100 != 0 || n % 400 == 0)
        return 1;
    return 0;
}

⛳️3.本题还去判断日期是否合理,我们知道年份是肯定没问题的,只要去判断月和每个月的天数,判断月份也很好判断,只要month<=12&&month>0。

但是每个月的天数就要根据具体的月份来定,所以我们定义非闰年时的每个月的天数。

如果天数满足day<=days[month]&&day>0就是满足的.

//定义非闰年情况的每个月的天数
int days[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };

⛳️4.设计符合题意的日期,也就是该函数用来判断一个日期是否存在,并且结构体里的日期不能重复。

year传过来的是一个两位数,要通过判断是否大于等于60来判断是2000年还是1900年。判断完以后把year变为正确值。

然后就是判断是否存在该日期,也就是判断月份和每个月的天数。❗️但是有一个点,就是,我们前面弄的是非闰年的每个月天数,如果我们判断该年是闰年,那么我们就去把days【2】+1,在函数末尾再变为非闰年的每个月天数。

month > 0 && month <= 12 && day < days[month] && day>0

判断完这个以后,就是去判断是否重复,先定义一个参考值flag,通过for循环去判断,如果重复了

就改变flag的值,然后跳出循环,最后判断flag的值就可以知道是否重复,没有重复的就可以赋值给结构体数组。

void judge(int year, int month, int day)
{
    int flag = 1;    //标记日期是否重复

    //把年份变为正确的年份
    if (year < 60)
        year += 2000;
    else
        year += 1900;

    //年份可以不用判断,肯定会满足题意的
    //只要去判断月份,每个月的天数就可以
    if (is_leap_year(month))
        days[2]++;        //如果是闰年,就把天数变为29天

    if (month > 0 && month <= 12 && day < days[month] && day>0)
    {
        //判断是否重复
        for (int i = 0; i < k; i++)
        {
            if (data[i].year == year && data[i].month == month && data[i].day)
            {
                flag = 0;
                break;
            }
        }

//没有重复就放入结构体数组
        if (flag)
        {
            data[k].year = year;
            data[k].month = month;
            data[k].day = day;
            k++;        //k为结构体里放了几个有效值,一开始为0
        }


    }


    //别忘记变为非闰年时,二月的天数
    if (is_leap_year(year))
        days[2]--;
}

 ⛳️4.现在的情况就是:日期数组里已经放好了,但是我们还没有进行排序,下面在main函数中进行排序。并且利用去qsort函数:

int cmp(const void* x, const void* y)
{
    if (((DATA*)x)->year > ((DATA*)y)->year)
        return 1;
    else if (((DATA*)x)->year < ((DATA*)y)->year)
        return 0;
    else
    {
        if (((DATA*)x)->month > ((DATA*)y)->month)
            return 1;
        else if (((DATA*)x)->month < ((DATA*)y)->month)
            return 0;
        else
        {
            if (((DATA*)x)->day > ((DATA*)y)->day)
                return 1;
            else
                return 0;
        }
    }
}

int main()
{
    int a, b, c;
    scanf("%d/%d/%d", &a, &b, &c);

    judge(a, b, c);        //可能为年,月,日
    judge(c, a, b);        //可能为月,日,年
    judge(c, b, a);        //可能为日,月,年

    qsort(data, k, sizeof(data[0]), cmp);

    for (int i = 0; i < k; i++)
        printf("%d-%02d-%02d\n", data[i].year, data[i].month, data[i].day);
    return 0;
}

 🌷 3.最终代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<stdlib.h>//定义非闰年情况的每个月的天数
int days[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };typedef struct DATA {int year;int month;int day;
}DATA;
DATA data[3];int k = 0;		//用于表示放了几个有效值//判断闰年的函数
int is_leap_year(int n)
{if (n % 4 == 0 && n % 100 != 0 || n % 400 == 0)return 1;return 0;
}void judge(int year, int month, int day)
{int flag = 1;	//标记日期是否重复//把年份变为正确的年份if (year < 60)year += 2000;elseyear += 1900;//年份可以不用判断,肯定会满足题意的//只要去判断月份,每个月的天数就可以if (is_leap_year(month))days[2]++;		//如果是闰年,就把天数变为29天if (month > 0 && month <= 12 && day < days[month] && day>0){//判断是否重复for (int i = 0; i < k; i++){if (data[i].year == year && data[i].month == month && data[i].day){flag = 0;break;}}if (flag){data[k].year = year;data[k].month = month;data[k].day = day;k++;}}//别忘记变为非闰年时,二月的天数if (is_leap_year(year))days[2]--;
}int cmp(const void* x, const void* y)
{if (((DATA*)x)->year > ((DATA*)y)->year)return 1;else if (((DATA*)x)->year < ((DATA*)y)->year)return 0;else{if (((DATA*)x)->month > ((DATA*)y)->month)return 1;else if (((DATA*)x)->month < ((DATA*)y)->month)return 0;else{if (((DATA*)x)->day > ((DATA*)y)->day)return 1;elsereturn 0;}}
}int main()
{int a, b, c;scanf("%d/%d/%d", &a, &b, &c);judge(a, b, c);		//可能为年,月,日judge(c, a, b);		//可能为月,日,年judge(c, b, a);		//可能为日,月,年qsort(data, k, sizeof(data[0]), cmp);for (int i = 0; i < k; i++)printf("%d-%02d-%02d\n", data[i].year, data[i].month, data[i].day);return 0;
}

总结:

我是菜鸡,我菜,所以我多练!

这篇关于蓝桥杯:日期问题(我的绝望题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/932068

相关文章

对postgresql日期和时间的比较

《对postgresql日期和时间的比较》文章介绍了在数据库中处理日期和时间类型时的一些注意事项,包括如何将字符串转换为日期或时间类型,以及在比较时自动转换的情况,作者建议在使用数据库时,根据具体情况... 目录PostgreSQL日期和时间比较DB里保存到时分秒,需要和年月日比较db里存储date或者ti

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas