鱼C论坛

 找回密码
 立即注册
查看: 3973|回复: 18

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

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

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

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

x
本帖最后由 清芷在沅湘 于 2022-4-6 22:38 编辑
  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 22:42:36
清芷在沅湘 发表于 2022-4-6 22:34
这是java 因为我先在Java版块发了一遍 但是我发现python版块人更多 加上这个问题主要是一个算法问题各个 ...

这样?

  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 main {
  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. }
复制代码
7.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

回帖奖励 +20 鱼币

抢沙发
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +20 鱼币

发代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

  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. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +20 鱼币

弱弱地问一句,这应该是Python吧,为什么在Java和Python交流区里都发了一遍
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-6 22:34:23 | 显示全部楼层
andy大宝 发表于 2022-4-6 22:31
弱弱地问一句,这应该是Python吧,为什么在Java和Python交流区里都发了一遍

这是java 因为我先在Java版块发了一遍 但是我发现python版块人更多 加上这个问题主要是一个算法问题各个语言是同的 所以我在python又发了一遍
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-6 22:42:36 | 显示全部楼层    本楼为最佳答案   
清芷在沅湘 发表于 2022-4-6 22:34
这是java 因为我先在Java版块发了一遍 但是我发现python版块人更多 加上这个问题主要是一个算法问题各个 ...

这样?

  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 main {
  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. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

对的对的,谢谢指点,我之前一直在草稿纸上手写模拟递归,一直不知道怎么处理最后一项,没有意识到递归函数也可以多参数的,再次感谢指点!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +20 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

回帖奖励 +20 鱼币

666666666666666666
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 06:46:31 | 显示全部楼层
清芷在沅湘 发表于 2022-4-6 22:34
这是java 因为我先在Java版块发了一遍 但是我发现python版块人更多 加上这个问题主要是一个算法问题各个 ...

哦误解了,以为是Python
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 07:16:02 | 显示全部楼层
清芷在沅湘 发表于 2022-4-6 22:34
这是java 因为我先在Java版块发了一遍 但是我发现python版块人更多 加上这个问题主要是一个算法问题各个 ...

https://fishc.com.cn/forum.php?m ... p;extra=#pid5799888

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 07:17:51 | 显示全部楼层
提个建议,提问题不要发这么多鱼币,像10鱼币以上的设一下阅读权限
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 07:30:30 | 显示全部楼层

回帖奖励 +20 鱼币

我觉得java简单。………………………………………………666
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 08:05:53 | 显示全部楼层

回帖奖励 +20 鱼币

java太卷了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +20 鱼币

支持
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-4-7 12:48:00 | 显示全部楼层
andy大宝 发表于 2022-4-7 07:17
提个建议,提问题不要发这么多鱼币,像10鱼币以上的设一下阅读权限

好的   谢谢提醒
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 14:02:13 | 显示全部楼层

回帖奖励 +20 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-4-7 21:10:34 | 显示全部楼层

回帖奖励 +20 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-15 07:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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