package com.taobao.tddl.sequence.util; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.Map; import java.util.Map.Entry; import java.util.Random; import com.taobao.tddl.sequence.exception.SequenceException; public class RandomSequence { /** * 产生包含0~n-1的n个数值的随机序列 * * @param n * @return * @throws SequenceException */ public static int[] randomIntSequence(int n) throws SequenceException { if (n <= 0) { throw new SequenceException("产生随机序列范围值小于等于0"); } int num[] = new int[n]; for (int i = 0; i < n; i++) { num[i] = i; } if (n == 1) { return num; } Random random = new Random(); if (n == 2 && random.nextInt(2) == 1) // 50%的概率换一下 { int temp = num[0]; num[0] = num[1]; num[1] = temp; } // for (int i = 0; i < n + 10; i++) { // int rindex = random.nextInt(n);// 产生0~n-1的随机数 // int mindex = random.nextInt(n); // int temp = num[mindex]; // num[mindex] = num[rindex]; // num[rindex] = temp; // } // return num; int[] result = randomIntSequence(num); return result; } /** * 乱序一个数组 * * @param sourceQueue * @return * @throws SequenceException */ public static int[] randomIntSequence(int[] sourceQueue) { int size = sourceQueue.length; Map<Integer, Integer> map = new HashMap<Integer, Integer>(size); Random random = new Random(); for (int i = 0; i < size; i++) { int randomNum = random.nextInt(size * 100); map.put(sourceQueue[i], randomNum); } ArrayList<Map.Entry<Integer, Integer>> resultQueue = sortByValueAsc(map); int[] result = new int[size]; for (int i = 0; i < size; i++) { result[i] = resultQueue.get(i).getKey(); } return result; } private static ArrayList<Map.Entry<Integer, Integer>> sortByValueAsc(Map<Integer, Integer> map) { ArrayList<Map.Entry<Integer, Integer>> list = new ArrayList<Map.Entry<Integer, Integer>>(map.entrySet()); Collections.sort(list, new Comparator<Map.Entry<Integer, Integer>>() { public int compare(Entry<Integer, Integer> arg0, Entry<Integer, Integer> arg1) { int result = -1; if (arg0.getValue() - arg1.getValue() > 0) { result = 1; } return result; } }); return list; } }