| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 10416 人关注过本帖
标题:递归调用 用递归方法求n!(n的阶乘)的值
取消只看楼主 加入收藏
yangt
Rank: 2
等 级:论坛游民
帖 子:49
专家分:20
注 册:2012-11-28
结帖率:61.11%
收藏
已结贴  问题点数:10 回复次数:0 
递归调用 用递归方法求n!(n的阶乘)的值
unsigned long mul(int n)   //定义函数mul,函数返回值类型为无符号长整形(4字节),定义形式参数n
{
    unsigned long p;       //无符号长整形(4字节)变量p
    if(n>1)                     
        p=n*mul(n-1);
    else
        p=1L;                              //请问这一句是什么意思呢?
        printf("p=%d  p的地址:%p\n",p,&p);
    return p;
}
main()
{
    int m;
    puts("calculate n!n=?\n");
    scanf("%d",&m);
    printf("%d!=%1d m的地址:%p\n",m,mul(m),&m);
    return 0;           //主函数为什么还要加return语句呢?加了return 0和不加有什么不同呢?
}

递归调用小弟脑袋就是转不过弯来了,这个程序是什么意思呢?
p=1L; 请问这一句是什么意思呢?
主函数为什么还要加return语句呢?加了return 0和不加有什么不同呢?

拜谢大神!


[ 本帖最后由 yangt 于 2014-2-4 11:38 编辑 ]
搜索更多相关主题的帖子: return 
2014-02-04 10:29
快速回复:递归调用 用递归方法求n!(n的阶乘)的值
数据加载中...
 
   



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

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