免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 7177 | 回复: 4
打印 上一主题 下一主题

用递归方法求数组前n个元素之和 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-07-17 14:00 |只看该作者 |倒序浏览
#include <stdio.h>

double CalcSum(int a[], int n);

int main(void)
{
        int a[] = {2147483647, 2147483647, 2147483647};
        double sum = CalcSum(a, sizeof(a) / sizeof(a[0]));
        fprintf(stdout, "sum = %.0lf\n", sum);
        return 1;
}

double CalcSum(int a[], int n)
{
        if (n <= 0)
        {
                return 0;
        }
        else
        {
                return double(a[n-1]) + CalcSum(a, n-1);
        }
}

程序执行结果为:
sum = 6442450941
这个没有问题!

如果把double CalcSum(int a[], int n)改为如下,程序执行结果依然正确!为什么没有发生越界呢?
double CalcSum(int a[], int n)
{
        if (n <= 0)
        {
                return 0;
        }
        else
        {
                return a[n-1] + CalcSum(a, n-1);
        }
}

论坛徽章:
89
水瓶座
日期:2014-04-01 08:53:31天蝎座
日期:2014-04-01 08:53:53天秤座
日期:2014-04-01 08:54:02射手座
日期:2014-04-01 08:54:15子鼠
日期:2014-04-01 08:55:35辰龙
日期:2014-04-01 08:56:36未羊
日期:2014-04-01 08:56:27戌狗
日期:2014-04-01 08:56:13亥猪
日期:2014-04-01 08:56:02亥猪
日期:2014-04-08 08:38:58程序设计版块每日发帖之星
日期:2016-01-05 06:20:00程序设计版块每日发帖之星
日期:2016-01-07 06:20:00
2 [报告]
发表于 2011-07-17 15:22 |只看该作者
纯粹的练习递归?

论坛徽章:
0
3 [报告]
发表于 2011-07-17 15:35 |只看该作者
回复 1# magic475


    为什么你觉得第二个应该发生越界呢?

   第一个的写法似乎有点问题
   return double(a[n-1]) + CalcSum(a, n-1);

论坛徽章:
0
4 [报告]
发表于 2011-07-17 19:02 |只看该作者
越界?说的原意是 溢出 吧?

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
5 [报告]
发表于 2011-07-17 19:49 |只看该作者
第二个,函数返回double,当然不会溢出了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP