java笔试题2

题目:输出一个数组里元素的所有组合。例如{1,2}输出{1,12,2,21}。要求时间复杂度尽量低一些。

下面是我自己写的代码:

package com.li.test.classes;
/**
 * 用递归的方法实现一个数组(元素为0-9),所有组合的输出
 */
import java.util.ArrayList;
import java.util.List;
public class ArrayCombinationtest {
	String[] stringarray = {};
	static List<String> list = new ArrayList();

	// 删除一个数组中下标为x的元素
	public Integer[] deletefirst(Integer[] array, int x) {
		ArrayList<Integer> arr = new ArrayList();
		for (int j = 0; j < array.length; j++) {
			if (j != x) {
				arr.add(array[j]);
			}
		}
		return arr.toArray(new Integer[arr.size()]);
	}

	// 递归实现所有组合的存储
	public List<String> arrayCombination(Integer[] array) {
		List<String> stringlist = new ArrayList();
		for (int i = 0; i < array.length; i++) {
			String str = array[i].toString();
			stringlist.add(str);
			List<String> str1 = new ArrayList();

			if (array.length > 1) {
				Integer[] arr = deletefirst(array, i);
				str1 = arrayCombination(arr);
				if (str1.size() > 0) {
					for (String s : str1) {
						String str2 = str + s;
						stringlist.add(str2);
					}
				}
			}
		}
		return stringlist;
	}

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ArrayCombinationtest combination = new ArrayCombinationtest();
		Integer[] array = { 1, 2, 3 };
		long start = System.nanoTime();
		System.out.println(combination.arrayCombination(array));//如果不打印,只运行递归方法,运行时间大约为600微秒。
		System.out.println(System.nanoTime() - start);
	}
}
运行结果:
[1, 12, 123, 13, 132, 2, 21, 213, 23, 231, 3, 31, 312, 32, 321]
1042318
注:运行时间取决于计算机状态,会有较大出入。
面试宝典给出的代码:

package com.li.test.classes;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
public class Arraytest {

	public static void listAll(List candidate, String prefix) {
		System.out.println(prefix);//如果注释掉该条语句,即不打印结果,运行时间大约为400-500微秒,说明打印语句很耗时间,在递归中要尽量避免。
		for (int i = 0; i < candidate.size(); i++) {
			List temp = new LinkedList(candidate);
			listAll(temp, prefix + temp.remove(i));
		}
	}

	public static void main(String[] args) {
		String[] array = new String[] { "1", "2", "3" };
		long start = System.nanoTime();
		listAll(Arrays.asList(array), "");
		System.out.println(System.nanoTime() - start);
	}
}
运行结果:
1
12
123
13
132
2
21
213
23
231
3
31
312
32
321
1721323
注:System.out.println("ssss");打印一个字符串运行时间大约为80微秒。一定要避免在递归算法中使用打印语句,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值