| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 389 人关注过本帖
标题:求解答万分感谢
只看楼主 加入收藏
小生求指教
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2014-12-12
结帖率:0
收藏
已结贴  问题点数:20 回复次数:8 
求解答万分感谢
用递归函数编程计算1!+3!+5 +···+n!(n为奇数)
2014-12-12 09:05
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:4 
n 想计算到多大呢

DO IT YOURSELF !
2014-12-12 09:08
小生求指教
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2014-12-12
收藏
得分:0 
回复 2楼 wp231957
n是自己控制输入的
2014-12-12 09:14
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
回复 3楼 小生求指教
所问非所答

DO IT YOURSELF !
2014-12-12 09:15
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9032
专家分:54061
注 册:2011-1-18
收藏
得分:4 
以下是引用小生求指教在2014-12-12 09:14:02的发言:

n是自己控制输入的

别人问的是“n允许的最大值”,而不是问“n从何而来”
2014-12-12 09:53
Discen
Rank: 2
等 级:论坛游民
帖 子:9
专家分:32
注 册:2014-9-21
收藏
得分:4 
程序代码:
#include <stdio.h>
int fan (int n);
int main ()
{
    int n,s;
    printf("Enter an integer:\n");
    scanf("%d",&n);
    s=fan(n);
    printf("1^2+2^2+...+n^2= %d\n",s);
    return 0;
} // main

int fan (int n)
{
    if(n==1)
        return 1;
    else
        return n*n+fan(n-1);
} // fan
2014-12-12 10:47
wyw19880809
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:3
帖 子:178
专家分:738
注 册:2013-3-14
收藏
得分:4 
回复 6楼 Discen
int的阶乘用int来装,小心溢出
2014-12-12 10:54
诸葛欧阳
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:流年
等 级:贵宾
威 望:82
帖 子:2790
专家分:14619
注 册:2014-10-16
收藏
得分:4 
二楼的问题应该就是防止溢出

一片落叶掉进了回忆的流年。
2014-12-12 11:09
longwu9t
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:6
帖 子:732
专家分:2468
注 册:2014-10-9
收藏
得分:4 
程序代码:
#include <stdio.h>
//gcc编译时取消下行注释
//#include <inttypes.h>

unsigned long long foobar(int n) {
    unsigned long long foo;

    if(1 == n || 0 == n) {
        foo = 1;

    } else {
        foo = foobar(n - 1) * n;
    }

    return foo;
}

unsigned long long add(int n) {
    unsigned long long sum = 0;

    if(1 == n) {
        sum = 1;

    }  else {
        sum = add(n - 2) + foobar(n);
    }

    return sum;
}

int main(void) {
    int n;
    printf("INPUT N: ");
    scanf("%d", &n);

    if(n >= 3 && n % 2 != 0) {
        //gcc编译时取消下行注释
        //printf("1!+3!+...+n! = %"PRIu64"\n", add(n));
        printf("1!+3!+...+n! = %lld\n", add(n));

    } else {
        printf("input arror!\n");
    }

    return 0;
}

Only the Code Tells the Truth             K.I.S.S
2014-12-12 12:58
快速回复:求解答万分感谢
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.058224 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved