鱼C论坛

 找回密码
 立即注册
查看: 1208|回复: 0

递归归去来兮,这样用应该不算是递归吧?

[复制链接]
发表于 2015-3-23 19:00:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 haiouda 于 2015-3-23 19:06 编辑
/********************************************************************
有 n 个整数,使前面各数顺序向后移 m 个位置,最后 m 个数变成最前面 m
个数。写一函数实现以上功能,在主函数中输入 n 个整数和输出调整后的 n
个数。
*********************************************************************/

#if(1)
#include <stdio.h>
int main()
{
        void move(int [20],int,int);
        int number[20],n,m,i;
        printf("how many numbers?");
        scanf("%d",&n);
        printf("input %d numbers:\n",n);
        for (i=0;i<n;i++)
                scanf("%d",&number[i]);
        printf("how many place you want move?");
        scanf("%d",&m);
        move(number,n,m);
    printf("Now,they are:\n");
        for (i=0;i<n;i++)
                printf("%d",number[i]);
        printf("\n");
        return 0;
}


#if(0)
void move(int array[20],int n,int m)
{
        int *p,array_end;
        array_end=*(array+n-1);
        
        for (p=array+n-1; p>array; p--)          *p=*(p-1);
        
        *array=array_end;
        m--;
        
        if (m>0)  move(array,n,m);
}
#endif

#if(1)
void move(int array[20],int n,int m)
{
        int *p,array_end;
        
        for (m;m>0;m--)
        {
                array_end=*(array+n-1);
                
                for (p=array+n-1; p>array; p--)          *p=*(p-1);
                
                *array=array_end;
        }
    
}

#endif
#endif
递归:归去来兮!
上面第29行到60行 有二个 #if() #endif   我把第二个 #if() #endif  用循环语句替代

第一个   #if() #endif  这样用,不算递归吧(只有其形没有其实!)?      


递归:递归归去来兮!



想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-25 19:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表