鱼C论坛

 找回密码
 立即注册
查看: 1847|回复: 9

[已解决]200鱼币悬赏!!!如何将问题中的循环转换成递归??

[复制链接]
发表于 2022-4-6 21:57:49 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 清芷在沅湘 于 2022-4-6 22:37 编辑
  1. import java.util.Scanner;

  2. public class Puzzle{
  3.         public static void main(String[] args){
  4.                 Scanner input = new Scanner(System.in);
  5.                 System.out.print("请输入n的值:");
  6.                 int n = input.nextInt();
  7.                 int i;
  8.                 double last = n;
  9.                 for (i = n;i > 0;i--){
  10.                          last = i-1 + 1.0/last;
  11.                 }
  12.                 System.out.println("答案是" + last);
  13.         }
  14. }
复制代码
如何将图中的循环转换成递归??
最佳答案
2022-4-6 23:10:15
200鱼币结贴吧
  1.         public static double myLast(double n ,double l) {
  2.                 if (n==1){ // 结束条件
  3.                         return n-1+1.0/l;
  4.                 }else {
  5.                        
  6.                         return myLast(n-1, n-1+1.0/l); //递归
  7.                 }
  8.         }
复制代码
7.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-4-6 22:58:19 | 显示全部楼层
  1. /*
  2. import java.util.Scanner;

  3. public class main {
  4.     public static void main(String[] args) {
  5.         Scanner input = new Scanner(System.in);
  6.         System.out.print("请输入n的值:");
  7.         int n = input.nextInt();
  8.         int i;
  9.         double last = n;
  10.         for (i = n; i > 0; i--) {
  11.             last = i - 1 + 1.0 / last;
  12.         }
  13.         System.out.println("答案是" + last);
  14.       }
  15. }
  16. */

  17. import java.util.Scanner;

  18. public class Puzzle2{
  19.     public static double calc(int n, double last) {
  20.         if(n <= 0) return last;
  21.         return calc(n - 1, n - 1 + 1.0 / last);
  22.     }
  23.     public static void main(String args[]) {
  24.         Scanner input = new Scanner(System.in);
  25.         System.out.print("请输入n的值: ");
  26.         int n = input.nextInt();
  27.         System.out.println("答案是: " + calc(n, n));
  28.         input.close();
  29.     }
  30. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-6 22:10:23 | 显示全部楼层

回帖奖励 +40 鱼币

抢沙发
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-6 22:22:21 | 显示全部楼层

回帖奖励 +40 鱼币

是指for循环吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-6 22:27:27 | 显示全部楼层

这不已经是for循环了吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-6 23:05:03 | 显示全部楼层

回帖奖励 +40 鱼币

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

使用道具 举报

 楼主| 发表于 2022-4-6 23:08:14 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-6 23:10:15 | 显示全部楼层    本楼为最佳答案   

回帖奖励 +40 鱼币

200鱼币结贴吧
  1.         public static double myLast(double n ,double l) {
  2.                 if (n==1){ // 结束条件
  3.                         return n-1+1.0/l;
  4.                 }else {
  5.                        
  6.                         return myLast(n-1, n-1+1.0/l); //递归
  7.                 }
  8.         }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 00:36:25 | 显示全部楼层

回帖奖励 +40 鱼币

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

使用道具 举报

发表于 2022-4-7 08:14:16 | 显示全部楼层
好高级,学习学习
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-12 15:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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