栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

用C++写洛谷P1028 [NOIP2001 普及组] 数的计算

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用C++写洛谷P1028 [NOIP2001 普及组] 数的计算

题目描述

我们要求找出具有下列性质数的个数(包含输入的正整数 nn)。

先输入一个正整数 nn(n le 1000n≤1000),然后对此正整数按照如下方法进行处理:

  1. 不作任何处理;

  2. 在它的左边拼接一个正整数,但该正整数不能超过原数,或者是上一个被拼接的数的一半;

  3. 加上数后,继续按此规则进行处理,直到不能再加正整数为止。

输入格式

一行,一个正整数 nn(n le 1000n≤1000)。

输出格式

一个整数,表示具有该性质数的个数。

输入输出样例

输入 #1复制

6

输出 #1复制

6
说明/提示

【样例解释】

满足条件的数为:66,1616,2626,126126,3636,136136。

AC代码:

#include 
using namespace std;
int main(){
	
	int n;
	int f[1001] = {0};
    cin >> n;
    
    for(int i = 1;i <= n;i++){
        for(int j = 1;j <= i/2;j++){
            f[i] = f[i] + f[j];
        }
        f[i]++;
    }
    
    cout << f[n];
    
	return 0;
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/847897.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号