数的计算

本文介绍了一种算法,用于计算符合特定生成规则的自然数序列的数量。这些数可以通过在原数左侧添加不超过其一半的自然数来生成。文章提供了一个C语言实现的例子,并通过样例解释了满足条件的数。
  • Description

要求找出具有下列性质数的个数(包含输入的自然数n):
先输入一个自然数n(n<=1000),然后对此自然数按照如下方法进行处理:
- 不作任何处理;
- 在它的左边加上一个自然数,但该自然数不能超过原数的一半;
- 加上数后,继续按此规则进行处理,直到不能再加自然数为止.
- Input

一个自然数n

  • Output

一个数,表示满足条件的数的个数

  • Sample Input

6

  • Sample Output

6

  • Hint

样例说明:满足条件的数是6,16,26,126,36,136

#include<stdio.h>
#include<stdlib.h>
int main()
{ 
    int i,j,n,t=0,a[501]={1,1,};
    scanf("%d",&n);
    for(i=2;i<=n/2;i++)
    {    
        for(j=1;j<=i/2;j++)
           a[i]+=a[j];
        a[i]=a[i]+1;
    }
    for(i=1;i<=n/2;i++)
            t=t+a[i];
    printf("%d\n",t+1);
    return 0;
}  
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值