日期模拟题目方法总结

  • 日期题目常用函数摸版
//判断是否为闰年
int is_leap(int year)
{
    if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
        return 1;
    return 0;
}

//获取某一年某一月的天数
int get_days(int year, int month)
{
    if(month == 2)  return months[month] + is_leap(year);
    else return months[month];
}

//逐天模拟
void next()
{
    if( ++ minute == 60)
    {
        minute = 0;
        if( ++ hour == 24)
        {
            hour = 0;
            week = (week + 1) % 7;
            if( ++ day > get_days(year, month))
            {
                day = 1;
                if( ++ month > 12)
                {
                    month = 1;
                    year ++ ;
                }
            }
        }
    }
}
  • 核心思想:遍历每一个时间点,对每一个时间点判断所需完成的操作命令(可能为check,可能为输出)
  • 考点1:通过以上三个函数简单模拟求解一些“输出某年某月第几天”的问题
  • 考点2:通过添加星期来提高难度。
    这种情况下通常需要在前面的基础上,在模拟月份中添加 week 变量表示星期;
    通过 week = (week + days) % 7等操作来计算星期;
    例题:https://www.acwing.com/problem/content/description/3217/
  • 考点3:需要处理复杂日期的存储, 或是在某日期安排某个事务。
    这种情况往往需要使用结构体存储 Task, Timer,在结构体中可以添加所需的函数来辅助模拟。
    例题:https://www.acwing.com/problem/content/3257/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值