制作递归方法以在 java 中打印文本

Making a recursive method to print a text in java

我必须制作一个像这样工作的程序。首先它从输入中获取一个数字,然后获取 (number) * strings.

例如:

2
a b

3
x1 x2 x3

然后在输出中打印如下内容:

Math.max(a, b)

Math.max(x1, Math.max(x2, x3))

我想用这段代码制作 Math.max 方法语法。希望你明白!

另一个示例输入和输出:

输入=

4
a b c d

输出=

Math.max(a, Math.max(b, Math.max(c, d)))

有人可以帮助我吗?

我为它写的代码,你能给我一些修改建议吗?

import java.util.*;

public class Main {
  public static void main(String[] args) {
    Scanner input = new Scanner(System.in);
    int n = input.nextInt();
    String[] r = new String[n];
    for (int i = 0; i < n; i++) {
      r[i] = input.next();
    }
    printmax(r);

  }
  public static int i = 0 , j = 0;
  public static boolean last = false;
  public static void printmax(String [] r){
    if (last == true) {
      System.out.print(r[r.length - 1]);
      while (j < r.length - 1){ System.out.print(")");
        j++;
      }
    }
    if (r.length == 2) System.out.print("Math.max(" +r[0] + ", " + r[1] + ")");
    if (r.length > 2) {
      while (i < r.length -1) {
        if (i == r.length -2) last = true;
        System.out.print("Math.max(" + r[i] + ", ");
        i++;
        printmax(r);
      }
    }
  }
}

你可以使用下面的代码来实现上面的,这里m递归调用maxElement()函数来实现这样的事情Math.max(a, Math.max(b, Math.max (c, d)))

public static void main(String args[]){
    int length = 2; //here read the input from scanner
    String[] array = {"a", "b"}; //here read this input from scanner
    String max = maxElement(array,0,length);
    System.out.println(max);
}
    
public static String maxElement(String[] start, int index, int length) {
    if (index<length-1) {
        return "Math.max(" + start[index]  +  ", " + maxElement(start, index+1, length)+ ")";
    } else {
        return start[length-1];
    }
}

输出: Math.max(a, b)

你需要做这样的事情。

首先你定义一个函数maxElement,它将你的变量数组作为参数。

public static maxElement(String[] variables) {
    return maxElementBis(variables,0);
}

然后调用第二个函数:maxElementBis,它带有一个附加参数,表示我们正在处理的变量的 索引

public static String maxElementBis(String[] variables, int index) {
    if (variables.length < 2) 
        return "not enought variables";
    if (variables.length - index == 2)
        return "Math.max("+ variables[index]+","+variables[index + 1]+")";
    return "Math.max("+ variables[index]+","+maxElementBis(variables,index + 1)+")";

}

如果数组包含的变量少于两个,你就不能做你想做的事。

如果你只剩下两个变量,这就是你的停止条件,你可以直接returnMath.max(v1,v2)

否则你递归调用你的函数maxElementBis.