| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1770 人关注过本帖, 2 人收藏
标题:指针、递归方法
只看楼主 加入收藏
so_love
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:7
帖 子:812
专家分:4151
注 册:2013-11-25
收藏
得分:4 
#include
#include<stdio.h>
int mult(int *n)
{
     int m;
     m=*n-1;              //这个   m=*n-1是为后面递归用的   因为mult(&(*n-1))有问题 我才换的这个
     if(*n==1)
         result=1;
     else
         result=mult(&m)*(*n);    //这个。。。递归阶乘么。5*4*3*2*1.。。。就是这个意思。
     return result;
}      

一花一世界、一叶一追寻、片片花叶落、情系何人身。
2013-12-05 17:44
IceSource
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:37
专家分:139
注 册:2013-12-3
收藏
得分:0 
#include<stdio.h>
int mult(int *n)
{
    int result;
    int m = *n;
    if(*n==1)
        result=1;
    else
        result=mult(&(--m))*(*n); //函数参数是指针类型
    return result;
}
int main()
{
    int n,sum=0,i=0;
    printf("输入一个整数:");
    scanf("%d",&n);
    for(i=1;i<=n;i++)
    {
       // x=x*i;   x可以不需要
        sum=sum+mult(&i);
    }
    printf("1!+...%d!=%d",n,sum);
    putchar('\n');
    return 0;
}

2013-12-05 17:55
qq1274371820
Rank: 1
等 级:新手上路
帖 子:149
专家分:0
注 册:2013-11-24
收藏
得分:0 
回复 22楼 IceSource


  但是这一行:     result=mult(&(--m))*(*n);   
  报错了:        error C2102: '&' requires l-value

          这个又是什么意思哇?

自定义人生。。。
2013-12-05 18:00
BlackTrace
Rank: 2
等 级:论坛游民
帖 子:16
专家分:22
注 册:2013-12-5
收藏
得分:0 
回复 23楼 qq1274371820
我问了一下,是因为啥左值的问题,&(*n--)相当于&(5+2)这是不行的,这是她们给我说的,必须单独提出来写
2013-12-05 18:31
renaa
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2013-12-5
收藏
得分:0 
我也想学,请各位帮帮
2013-12-05 20:00
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:0 
//1!+2!+3!+...+n!
#include<stdio.h>
int fun2(int *n)//积
{
    int c;
    if(1==*n)
        return 1;
    else
        c=*n-1;
    return fun2(&c)*(*n);
}
int fun1(int *n)//和
{
    int b;
    if(1==*n)
        return 1;
    else
        b=*n-1;
    return fun1(&b)+fun2(&b);
}
int main()
{
    int n,a;
    printf("n=");
    scanf("%d",&n);
    a=n+1;
    printf("%d\n",fun1(&a)-1);
    return 0;
}

[ 本帖最后由 小小战士 于 2013-12-5 20:35 编辑 ]

小小战士,战士中的战斗机!
2013-12-05 20:04
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:0 
#include<stdio.h>
int mult(int *n)
{
    int a;
    if(1==*n)
        return 1;
    else
        a = *n-1;
    return mult(&a)*(*n);
}
int main()
{
    int n,i,sum=0;
    printf("输入一个整数:");
    scanf("%d",&n);
    for(i=1;i<=n;i++)
        sum += mult(&i);
    printf("1!+...%d!=%d",n,sum);
    putchar('\n');
    return 0;
}

[ 本帖最后由 小小战士 于 2013-12-5 20:43 编辑 ]

小小战士,战士中的战斗机!
2013-12-05 20:37
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:2 
楼主有两处错误
#include<stdio.h>
int mult(int *n)
{
    int result;
    int a=*n-1;
    if(*n==1)
        result=1;
    else
        //result=mult(*n-1)*(*n);//将整形传给指针,编译错误
        result=mult(&a)*(*n);
    return result;
}
int main()
{
    int n,sum=0,i;
    printf("输入一个整数:");
    scanf("%d",&n);
    for(i=1;i<=n;i++)
    {
        //sum=sum+mult(&n);//用定值传参,结果不对,应该用循环变量
        sum=sum+mult(&i);
    }
    printf("1!+...%d!=%d",n,sum);
    putchar('\n');
    return 0;
}

[ 本帖最后由 小小战士 于 2013-12-5 21:29 编辑 ]

小小战士,战士中的战斗机!
2013-12-05 21:27
一只小狼
Rank: 1
来 自:辽宁沈阳
等 级:新手上路
帖 子:5
专家分:8
注 册:2013-12-2
收藏
得分:0 
#include<stdio.h>
int mult(int *n)
{
    int p;
    int result;
    p=*n-1;   
    if(*n==1)
        result=1;
    else
        result=mult(&p)*(*n);
    return result;
}
int main()
{
    int n,sum=0,i,x=1;
    printf("输入一个整数:");
    scanf("%d",&n);
    for(i=1;i<=n;i++)
    {
        sum=sum+mult(&i);
    }
    printf("1!+...%d!=%d",n,sum);
    putchar('\n');
    return 0;
 }
2013-12-06 09:30
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
收藏
得分:0 
不给改代码就一分都没有?

总有那身价贱的人给作业贴回复完整的代码
2013-12-06 09:48
快速回复:指针、递归方法
数据加载中...
 
   



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

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