Java递归求解数组里“数组合”

输出描述:


给定的数组有多少个“数组合”

输入例子:


3

1 2 3

输出例子:


15

解题思路,本题可以考虑使用循环递归的算法:

以下代码仅供参考


import java.util.ArrayList;

import java.util.LinkedList;

import java.util.List;

import java.util.Scanner;





public class Main{

        static int index=0;

	public static void main(String[] args) {

		Scanner mScanner=new Scanner(System.in);

		int num=mScanner.nextInt();

		List<String> array=new ArrayList<String>();

		for (int i = 0; i < num; i++) {

			array.add(mScanner.next()+"");

		}

        listAll(array, "");

        System.out.println(index-1);

	}



	public static void listAll(List list, String prefix) {

		index++;

		//if (list.isEmpty()) {

		 // System.out.print(prefix+" ");

	    //}

		int len = list.size();

		for (int i = 0; i < len; i++) {

			List temp = new LinkedList(list);

			listAll(temp, prefix + temp.remove(i));

		}

	}

}



后来我又想了下,觉得这样理解

假设输入数据为n,输出的结果为f(n).

### 回答1: public class Fibonacci { public static void main(String[] args) { int n = 10; int[] fibonacci = new int[n]; fibonacci[0] = 0; fibonacci[1] = 1; for (int i = 2; i < n; i++) { fibonacci[i] = fibonacci[i - 1] + fibonacci[i - 2]; } System.out.println("Fibonacci sequence:"); for (int i = 0; i < n; i++) { System.out.print(fibonacci[i] + " "); } } } ### 回答2: Fibonacci数列是以递归的方式定义的数列,其中每个数字都是前两个数字的和。以下是使用Java递归实现Fibonacci数列,并使用数组存储结果的代码: ```java public class Fibonacci { public static void main(String[] args) { int n = 10; // 为了演示目的,假设我们要计算前10个Fibonacci数字 int[] fibonacciSeries = new int[n]; // 计算Fibonacci数列 for (int i = 0; i < n; i++) { fibonacciSeries[i] = fibonacci(i); } // 打印结果 System.out.println("Fibonacci数列前" + n + "个数字为:"); for (int i : fibonacciSeries) { System.out.print(i + " "); } } // 递归计算Fibonacci数列 public static int fibonacci(int n) { if (n <= 1) { return n; } return fibonacci(n - 1) + fibonacci(n - 2); } } ``` 以上代码首先定义了一个大小为n的整型数组`fibonacciSeries`,然后通过循环计算Fibonacci数列,并将结果保存在数组中。最后,通过循环遍历数组并打印结果。 需要注意的是,递归实现的Fibonacci数列在计算大量数字时可能会非常慢,因为它会反复计算相同的数字。可以通过使用动态规划或迭代的方式进行改进,以提高效率。 ### 回答3: Fibonacci数列是指从第3项开始,每一项都是前两项的和,即F(n) = F(n-1) + F(n-2)。要用Java递归实现Fibonacci数列,并用数组存放,可以按照以下步骤实现: 1. 创建一个长度为n+1的数组,用于存放Fibonacci数列的结果。 2. 编写一个递归方法,用于计算Fibonacci数列的每一项。该方法接受一个整数n作为参数,并返回F(n)。 3. 在递归方法中,首先判断如果n小于等于1,直接返回n;如果n在数组范围内,即结果数组中已经有了对应的值,则直接返回该值。 4. 如果结果数组中没有对应的值,那么就递归调用自身求解F(n-1)和F(n-2),并将结果存入数组中。然后返回F(n)的值。 5. 在主方法中,调用递归方法,并将结果打印出来。 下面是Java代码实现: ```java public class Fibonacci { public static void main(String[] args) { int n = 10; // 要计算的Fibonacci数列的长度 int[] fibArr = new int[n + 1]; // 存放Fibonacci数列的数组 fibonacci(n, fibArr); // 调用递归方法计算Fibonacci数列 // 打印Fibonacci数列结果 for (int i = 0; i <= n; i++) { System.out.print(fibArr[i] + " "); } } public static int fibonacci(int n, int[] fibArr) { if (n <= 1) { return n; } if (fibArr[n] != 0) { return fibArr[n]; } int fib = fibonacci(n - 1, fibArr) + fibonacci(n - 2, fibArr); fibArr[n] = fib; return fib; } } ``` 以上代码通过递归的方式实现了Fibonacci数列,并使用数组存放结果。在计算过程中,根据需要将已经计算过的结果存入数组中,以便后续使用,避免重复计算,提高效率。运行结果将打印出Fibonacci数列的前n项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值