P1028 数的计算
-
- 23.5K通过
- 47.4K提交
- 题目提供者CCF_NOI
- 评测方式云端评测
- 标签NOIp普及组2001(或之前)
- 难度普及-
- 时空限制1000ms / 128MB
提交 题解
- 提示:收藏到任务计划后,可在首页查看。
最新讨论显示
推荐的相关题目显示
题目描述
我们要求找出具有下列性质数的个数(包含输入的自然数nn):
先输入一个自然数nn(n \le 1000n≤1000),然后对此自然数按照如下方法进行处理:
-
不作任何处理;
-
在它的左边加上一个自然数,但该自然数不能超过原数的一半;
-
加上数后,继续按此规则进行处理,直到不能再加自然数为止.
输入输出格式
输入格式:
11个自然数nn(n \le 1000n≤1000)
输出格式:
11个整数,表示具有该性质数的个数。
输入输出样例
输入样例#1: 复制
6
输出样例#1: 复制
6
说明
满足条件的数为
6,16,26,126,36,136
思路:
这个题的表述感觉很别扭,我也说不太清楚,直接说思路吧
对于一个数延伸出来的数,我们其实是不用加上原来的数再操作的,于是我们可以得出dp方程:
f[ x ] = 1;
for (int j = 1;j <= x / 2;j ++)
f[x] += f[j];
特别的,f [ 1] = 1;
代码:
#include<bits/stdc++.h>
using namespace std;
int f[1010];
void init()
{
f[1] = 1;
for (int i = 2;i <= 1000;i ++)
{
f[i] = 1;
for (int j = 1;j <= i / 2;j ++)
f[i] += f[j];
}
}
int main()
{
init();
int n;
scanf("%d",&n);
printf("%d\n",f[n]);
return 0;
}
P1149 火柴棒等式
-
- 16.6K通过
- 31.7K提交
- 题目提供者CCF_NOI
- 评测方式云端评测
- 标签NOIp提高组2008
- 难度普及-
- 时空限制1000ms / 128MB
提交