P1028 数的计算
-
- 27.6K通过
- 57.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
AC_CODE:
#include<bits/stdc++.h>//万能头文件
using namespace std;
int n;
int f[1001];//存每一位数的种类
int main() {
cin >> n;
for (int i = 1; i <= n; i++) { //1-n的递推
for (int j = 1; j <= i / 2; j++) {
f[i] += f[j]; //每一位叠加,递推走起
}
f[i]++; //加上本身
}
cout << f[n];//输出n的种类
return 0;
}