曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 5214|回复: 0
打印 上一主题 下一主题

[递归] 递归--两数相乘的算法实现

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34397
跳转到指定楼层
楼主
发表于 2008-11-16 22:40:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
该程序用递归的方法实现两数相乘:

#include <stdio.h>


int Multiply(int M, int N)
{
    int result;

    if( N == 1)
    {
    result = M;
    return result;
    }
    else
    {
    result = M + Multiply(M,N-1);
    }

    return result;
   
}

int main(void)
{
    int NumbA;
    int NumbB;
    int Product;

    printf("please input NumbA for NumbA*NumbB:");
    scanf("%d",&NumbA);
    printf("please input NumbB for NumbA*NumbB:");
    scanf("%d",&NumbB);

    Product = Multiply(NumbA, NumbB);

    printf("The Result is %d\n", Product);
 
    return 0;

}

说明

处理递归问题,常采用 if 语句来判断是否符合递归结束条件,其算法格式如下:

if (符合递归结束条件) then
   返回答案
else
使用递归将程序分割为更简单的小程序
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-6-17 14:00 , Processed in 0.064906 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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