P1028
2024-08-31 07:21:31
一开始没看懂题,看了题解才明白的 = =。思路是,先找规律,会发现有重合部分,利用这些重合部分,写出递推公式。
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;
}
最新文章
- mongoTemplate简单用法(增删改查)
- EF简单的添加修改删除基本语法
- java selenium (五) 元素定位大全
- Java面试常见各种概念区别比较
- POJ 1061青蛙的约会(拓展欧几里德算法)
- Eclipse CDT “Symbol NULL could not be resolved”
- js 执行效率
- ckeditor_4.5.10_full上传图片功能
- ExecuteNonQuary接收存储过程的输出类型的变量的值
- VS IDE环境下,windows GUI(Qt MFC,win32)使用控制台实时打印调试信息
- BroadcastReceiver基础总结
- mock.js-无需等待,随机产生数据,让前端独立于后端进行开发
- Lucene 02 - Lucene的入门程序(Java API的简单使用)
- caffe-ssd需要安装opencv
- 原创 《算法》java第四版,标准输入
- 配置Django
- contextlib 上下文管理器
- [Java]Spring Ioc讲解,不怕你不懂
- 通过AO连接多个EO并进行使用
- Mac下Python安装目录