java数组随机乱序且乱序后不在其原来的位置上(代码片段)

背景:因业务需要,需要对一个数组进行乱序,如:A、B、C、D相互交换顺序,交换顺序后要求每个人都不能拿到自己的编号,交换后:DCBA、DABC等符合要求,而ADCB、DBCA这类则不符合要求,背景说明完毕,上代码:

package com.sdzn.util;

import java.util.ArrayList;
import java.util.List;

public class RandomUtil {

    /**
     * main方法描述: 随机数工具
     * 
     * @author : Ricky
     * @createTime : Jun 19, 2015 1:16:54 PM
     * @param args
     */
    public static void main(String[] args) {
        for (int k = 0; k < 10000; k++) {
            int[] sort = {
                    1, 2, 3, 4, 5, 6, 7, 8, 9, 10
            };
            int[] newss = new RandomUtil().randomSort(sort);
            for (int p = 0; p < sort.length; p++) {
                if (sort[p] == newss[p]) {
                    System.out.println("相等了");
                }
            }
            if (k % 100 == 0) {
                System.out.println(k);
                for (int p = 0; p < sort.length; p++) {
                    System.out.print(newss[p] + " ");
                }
            }
        }
    }

    /**
     * randomSort方法描述: 将一个数组进行随机排序,使每个序列位置上的数字都不是原来的数字
     * 使用场景:****。
     * 
     * @author : Ricky
     * @createTime : Jun 19, 2015 3:38:55 PM
     * @param sort
     *            需要打乱顺序的数组
     * @return
     */
    public int[] randomSort(int[] sort) {
        List<Integer> sList = new ArrayList<Integer>();
        List<Integer> rList = new ArrayList<Integer>();
        int[] rSort = new int[sort.length];
        for (int s : sort) {
            sList.add(s);
        }
        int count = 0;
        Integer lastValue = null;
        while (sList.size() > 0) {
            int randSeq = getRandom(sList.size());
            if (sList.get(randSeq) != sort[count]) {
                rList.add(sList.get(randSeq));
                sList.remove(randSeq);
                count++;
            } else {
                if (count + 1 == sort.length) {
                    if (sList.get(randSeq) == sort[count]) {
                        lastValue = sort[count];
                        rList.add(sList.get(randSeq));
                        sList.remove(randSeq);
                    }
                    break;
                }
            }
        }
        for (int i = 0; i < rList.size(); i++) {
            rSort[i] = rList.get(i);
        }
        if (lastValue != null) {
            int t = rSort[sort.length - 1];
            int randomSeq = getRandom(sort.length - 1);
            rSort[sort.length - 1] = rSort[randomSeq];
            rSort[randomSeq] = t;
        }
        return rSort;
    }

    /**
     * getRandom方法描述: 获得小于quan的一个整数
     * 
     * @author : Ricky
     * @createTime : Jun 19, 2015 1:44:19 PM
     * @param quan
     *            产生的整形数字必须比它小
     * @return
     */
    private int getRandom(int quan) {
        int newInt = quan;
        while (!(newInt < quan)) {
            String randomStr = "" + quan * Math.random();
            if (randomStr.contains("."))
                randomStr = randomStr.substring(0, randomStr.indexOf("."));
            newInt = Integer.parseInt(randomStr);
        }
        return newInt;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值