一开始没看懂题,看了题解才明白的 = =。思路是,先找规律,会发现有重合部分,利用这些重合部分,写出递推公式。

  num = 0 时,只有 1 种组合;

  num = 1 时,只有 1 种组合;

  num = 2 时,有 12, 2 两种组合;

  num = 3 时,有 13, 3 两种组合(不能超过原数的一半);

  num = 4 时,有 124, 24, 14, 4 四种组合;

  ...

  如此下去,会发现 num 为奇数时等于 num - 1 的结果,而最基本的部分 num = 0, num = 1 是明确的。

  写出递推式:

$$ f[i] = \left\{\begin{aligned} 1 &\quad i = 1; \\ f[i/2] + f[i - 1] &\quad i \ is \ even; \\ f[i - 1] &\quad i \ is \ odd. \end{aligned} \right. $$

#include <bits/stdc++.h>
using namespace std;
#define rep(i, a, b) for(int i = a; i < b; i++)
#define min(a, b) ((a) < (b) ? (a) : (b))
#define max(a, b) ((a) > (b) ? (a) : (b))
#define index(a) (a - 'A')
#define transUpp(a) (a - 32)
#define transLow(a) (a + 32)
#define ll long long
#define PB push_back
int gcd(int a, int b){return b == 0 ? a : gcd(a%b, a);}
const int N = 100010;
int main()
{
int f[N], num;
cin >> num;
f[0] = 1;
for (int i = 1; i <= num; i++)
f[i] = ((i + 1) & 1) * f[i >> 1] + f[i - 1];
cout << f[num] << endl;
return 0;
}

  

最新文章

  1. mongoTemplate简单用法(增删改查)
  2. EF简单的添加修改删除基本语法
  3. java selenium (五) 元素定位大全
  4. Java面试常见各种概念区别比较
  5. POJ 1061青蛙的约会(拓展欧几里德算法)
  6. Eclipse CDT “Symbol NULL could not be resolved”
  7. js 执行效率
  8. ckeditor_4.5.10_full上传图片功能
  9. ExecuteNonQuary接收存储过程的输出类型的变量的值
  10. VS IDE环境下,windows GUI(Qt MFC,win32)使用控制台实时打印调试信息
  11. BroadcastReceiver基础总结
  12. mock.js-无需等待,随机产生数据,让前端独立于后端进行开发
  13. Lucene 02 - Lucene的入门程序(Java API的简单使用)
  14. caffe-ssd需要安装opencv
  15. 原创 《算法》java第四版,标准输入
  16. 配置Django
  17. contextlib 上下文管理器
  18. [Java]Spring Ioc讲解,不怕你不懂
  19. 通过AO连接多个EO并进行使用
  20. Mac下Python安装目录

热门文章

  1. Log4j的isdebugEnabled的作用
  2. Python 实现深度学习
  3. ASP.NET + MVC5 入门完整教程八 -—-- 一个完整的应用程序(上)
  4. java+selenium打开浏览器实现后台静默运行
  5. MySQL学习(六)change-buffer
  6. GO111MODULE
  7. 滑雪(dfs+dp)
  8. NW.js构建桌面应用
  9. 刷题72. Edit Distance
  10. C#中DataSet、SqlDataAdapter的使用-关于数据库操作