算法
(枚举,模拟) $O(10^4)$
由于只有八位数,而且回文串左右对称,因此可以只枚举左半边,这样只需枚举 $0 \sim 9999$ 总共一万个数,然后判断:
- 整个八位数构成的日期是否合法;
- 是否在范围内
时间复杂度
一共枚举 $10^4$ 个数,判断每个数是否合法的计算量是常数级别的,因此总计算量是 $O(10^4)$。
C++ 代码
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
int months[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
bool check(int date)
{
int year = date / 10000;
int month = date % 10000 / 100;
int day = date % 100;
if (!month || month >= 13 || !day) return false;
if (month != 2 && day > months[month]) return false;
if (month == 2)
{
bool leap = year % 4 == 0 && year % 100 || year % 400 == 0;
if (day > 28 + leap) return false;
}
return true;
}
int main()
{
int date1, date2;
cin >> date1 >> date2;
int res = 0;
for (int i = 0; i < 10000; i ++ )
{
int x = i, r = i;
for (int j = 0; j < 4; j ++ ) r = r * 10 + x % 10, x /= 10;
if (r >= date1 && r <= date2 && check(r)) res ++ ;
}
printf("%d\n", res);
return 0;
}
屌
太舒服了
这代码就帅的不谈
叼
int leap = year % 100 && year % 4 == 0 || year % 400 == 0;为啥符合条件的leap就等于1啊
因为是
bool
类型,true 转(int)(ture) = 1
(int)(false) = 0
你看y总发的另一个版本的代码 leap 是int 类型不是bool类型 为什么也可以等于1呀
你可以试试
cout << !0 << endl;
谢谢你!
y总nb!!!!
tql
太优雅了
orz
nb
#### tql ####
orz
请问 month = date /10000 % 100 和 month=date % 10000 /100 有啥不一样,前者错在哪了
例如20160102,前者算出来就是16,后者算出来是01这个月份
是的,当时脑子抽了,蟹蟹你
优雅
check函数可以当模板了
orz
这甜蜜的就像是艺术品!
牛