http://www.lydsy.com/JudgeOnline/problem.php?id=1026

1026: [SCOI2009]windy数

Time Limit: 1 Sec  Memory Limit: 162 MB
Submit: 5561  Solved: 2493
[Submit][Status][Discuss]

Description

  windy定义了一种windy数。不含前导零且相邻两个数字之差至少为2的正整数被称为windy数。 windy想知道,
在A和B之间,包括A和B,总共有多少个windy数?

Input

  包含两个整数,A B。

Output

  一个整数

Sample Input

【输入样例一】
1 10
【输入样例二】
25 50

Sample Output

【输出样例一】
9
【输出样例二】
20

HINT

【数据规模和约定】

100%的数据,满足 1 <= A <= B <= 2000000000 。

题意比较简单,这里有点蛋疼的是第一个样例我一开始看不懂,然后问了别人才知道例如第一个样例 1 10 的答案是 1 - 9。
所以可能最高位如果前面都是零的话,那么它可以任意选择一个数(0 - 位上限)
如果最高位前面不全都是零的话,那么它就要按照规则即和前一位相差2来取。
还是太弱了。

 #include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
using namespace std;
#define N 35
//long long dp[N][15][2][2];
long long dp[N][][];
int bit[N];
/*
zero判断前面是不是全都是 0,
1的话说明前面没有前导零,有值
0的话说明前面没有值,都是零
*/
//我一开始的写法
//long long dfs(int pos, int pre, int st, int zero, int flag)
//{
// if( !pos ) return st;
// if( zero && !flag && dp[pos][pre][st][zero] != -1 ) return dp[pos][pre][st][zero];
//
// long long ans = 0;
// int u = flag ? bit[pos] : 9;
//
// if( zero == 0 ){
// for(int i = 0; i <= u; i++){
// ans += dfs(pos - 1, i, i == 0 ? 0 : 1, i == 0 ? 0 : 1, flag && i==u);
// }
// }
// else{
// for(int i = 0; i <= u; i++){
// if( abs(pre - i) >= 2 ){
// ans += dfs(pos - 1, i, 1, 1, flag && i==u);
// }
// }
// }
//
// if( zero && !flag ) dp[pos][pre][st][zero] = ans;
// return ans;
//}
//看了别人的写法,简化了很多
long long dfs(int pos, int pre, int zero, int flag)
{
if( !pos ) return ;
if( zero && !flag && ~dp[pos][pre][zero] ) return dp[pos][pre][zero]; long long ans = ;
int u = flag ? bit[pos] : ; for(int i = ; i <= u; i++){
if( !zero || abs(pre - i) >= )
/*
例如第一个样例 1 10 的答案是 1 - 9
所以可能最高位如果前面都是零的话,那么它可以任意选择一个数(0 - u)
如果最高位前面不行全都是零的话,那么它就要按照规则即和前一位相差2来取
这一题的没有前导零还有第一个样例搞得我很迷糊。我还是太弱了
*/
ans += dfs(pos - , i, i || zero, flag && i==u);
}
if( !flag ) dp[pos][pre][zero] = ans;
return ans;
} long long solve(long long x)
{
int l = ;
while(x>){
bit[++l] = x % ;
x /= ;
}
// return dfs(l, 0, 0, 0, 1);
return dfs(l, , , );
} int main()
{
long long a, b;
cin >> a >> b;
memset(dp, -, sizeof(dp));
if(a > b) swap(a, b);
// cout << solve(b) << " " << solve(a-1) << endl;
cout << solve(b) - solve(a-) << endl;
return ;
}

最新文章

  1. Asp.Net Core 项目实战之权限管理系统(2) 功能及实体设计
  2. cogs 577 蝗灾 CDQ分治
  3. lua 使用
  4. zabbix_监控_端口
  5. Solr4.3之拼写检查Spellcheck功能
  6. RS485模块(485与TTL信号的转换)
  7. netty概念
  8. Loadrunner基础:Loadrunner Controller基本概念和使用
  9. spark1.3.1安装和集群的搭建
  10. mysql解决错误的方法-MySQL日志
  11. linux查询cpu核心数
  12. web开发 关于src跳转
  13. Linux下Django开发学习(一)
  14. 讨论oracle在rowid和rownum
  15. 「NOI2013」树的计数 解题报告
  16. 类 __getitem__ __getattr__ __call__
  17. RISC-V指令集介绍 - 整数基本指令集
  18. centos 安装python PIL模块
  19. MySql常用命令集Mysql常用命令2
  20. P4208 [JSOI2008]最小生成树计数

热门文章

  1. QT 等待对话框/进度--
  2. C# 读取大文件 (可以读取3GB大小的txt文件)
  3. JavaScript严格模式分析
  4. WPF如何判断PNG中的点是透明的
  5. WPF TextBlock 文字超长截断并显示省略符号
  6. MySql如何将一个表字段更新到另一个表字段
  7. 全面解析ECMAScript 6模块系统
  8. Delphi中取得汉字的首字母(十分巧妙)
  9. 彻底删除kafka topic步骤
  10. Windows服务(system权限)程序显示界面与用户交互,Session0通知Session1里弹出对话框(真的很牛) good