• 博客园logo
  • 会员
  • 周边
  • 众包
  • 新闻
  • 博问
  • 闪存
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

土鳖不土,战斗力五

天地玄宗,万炁本根。广修万劫,证吾神通。
  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

两个递归程序(数组最大元素,汉诺塔)

1、递归返回数组中最大元素

//返回数组中最大元素
int findMax(int a[], int n)
{
    int next = 0;
    if (n == 1) return a[0];
    next = findMax(&a[1], n-1);
    return a[0]>next ? a[0] : next;
}

 

2、汉诺塔

/*
汉诺塔:把盘子从A驻移动到C柱,大盘子时刻不能在小盘子之上
输入:n(盘子数目)
输出:步骤
*/
int hanoid(char A, char B, char C, int n)
{
    if (n == 0) return 0;
    if (n == 1)
    {
        printf("Move #%d from %c to %c\n", n, A, C);
        return 0;
    }
    else
    {
        hanoid(A, C, B, n-1);
        //hanoid(A, B, C, 1);
        printf("Move #%d from %c to %c\n", n, A, C);
        hanoid(B, A, C, n-1, step+2);
    }
    return 0;
}

 

posted on 2016-09-14 16:59  土鳖不土,战斗力五  阅读(326)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3