亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Java中打亂一個數組的2種公平算法分享

2019-11-26 15:14:38
字體:
來源:轉載
供稿:網友

公平算法,打亂數組

這是前幾天面試的時候遇見的一道題目,看到這個題首先想到了洗牌程序:

方法一:洗牌程序原理

在java.util包中的Collections類中的 shuffle方法,現在手工實現以下代碼如下:

package test.ms;import java.util.Random;public class Redistribute2 {	public static void main(String[] args) {				//define the array 		int[] s = {1,5,4,3,6,9,8,7,0,8,5,6,7,2};				// before redistribute output		System.out.println("before redistribute:");		for(int i = 0 ; i<s.length; i++){			System.out.print(s[i]+" ");		}				// invoke the method 		shuffle(s,new Random());				System.out.println();				// after redistribute output		System.out.println("after redistribute:");		for(int i = 0 ; i<s.length; i++){			System.out.print(s[i]+" ");		}	}  	// using the random get the random number	public static  void  shuffle(int[] array, Random random){				for(int i = array.length; i >= 1; i--){						swap(array,i-1,random.nextInt(i));		}	}		// the two number swap  in the array	public static void swap(int[] array, int i , int j){	 		int temp = array[i];				array[i] = array[j];				array[j] = temp;	 			}}


swap方法用于交換數組中的兩個數,  shuffle方法 用于 根據隨機源 生成的隨機數進行交換。
輸出結果如下:

before redistribute:1 5 4 3 6 9 8 7 0 8 5 6 7 2 after redistribute:9 8 7 8 0 6 1 6 5 5 2 3 7 4 


方法二:生成隨機索引交換

該方法利用Set集合的特性:Set集合中的數據不重復,生成數組的索引,根據生成的索引進行交換數據。

實現方式如下:

package test.ms;import java.util.Iterator;import java.util.LinkedHashSet;import java.util.Random;import java.util.Set;public class Redistribute {		public static void main(String[] args) {		int[] s = {1,5,4,3,6,9,8,7,0,8,5,6,7,2};		redistribute(s);	}	public static void  redistribute(int[] s){		Random  random = new Random();				Set<Integer> set = new LinkedHashSet<Integer>();				// redistribute the  index		while(true){			int t =random.nextInt(s.length);			set.add(t);			if(set.size()== s.length)			break;		}		System.out.println("before redistribute:");		for(int i = 0 ; i<s.length; i++){			System.out.print(s[i]+" ");		}		System.out.println();		System.out.println("redistribute the index ");System.out.println(set);				int [] out = new int[s.length];				int count = 0;				for(Iterator<Integer> iterator = set.iterator(); iterator.hasNext();){			out[count] = s[iterator.next()];			count++;		}				// out the result;		System.out.println("after redistribute:");		for(int i = 0 ; i<s.length; i++){			System.out.print(out[i]+" ");		}	}	}

這個方法首先生成索引,然后根據新索引進行數據交換,代碼都寫在main方法里了,不是太好。

生成結果如下:

before redistribute:1 5 4 3 6 9 8 7 0 8 5 6 7 2 redistribute the index [6, 2, 9, 1, 10, 5, 11, 4, 12, 3, 7, 8, 0, 13]after redistribute:8 4 8 5 5 9 6 6 7 3 7 0 1 2 


關于隨機數的生成,用了java類中的隨機數的生成的工具類,這個隨機類需要單獨研究一下。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品一区二区三区婷婷月| 国产一区二区三区欧美| 亚洲国产一区自拍| 亚洲欧美成人精品| 亚洲精品中文字幕av| 久久视频在线免费观看| 亚洲视频视频在线| 91高清视频在线免费观看| 欧美午夜精品久久久久久久| 91精品免费视频| 亚洲激情在线观看| 日韩av在线网站| 欧美日韩亚洲精品内裤| 自拍偷拍亚洲欧美| 久久精品视频中文字幕| 最近2019年好看中文字幕视频| 国产在线高清精品| 精品国产鲁一鲁一区二区张丽| 欧洲成人午夜免费大片| 精品自拍视频在线观看| 在线视频欧美日韩精品| 国产视频丨精品|在线观看| 国产在线98福利播放视频| 成人激情视频网| 中文字幕日韩欧美在线视频| 欧美午夜视频一区二区| 韩国欧美亚洲国产| 欧美黑人xxx| 国产精品视频白浆免费视频| 在线视频欧美日韩| 一区二区三区四区精品| 尤物九九久久国产精品的分类| 精品国产网站地址| 国产精品一二三在线| 中文字幕国产日韩| 欧美一级电影久久| 91在线网站视频| 日韩中文在线观看| 91久久国产精品91久久性色| 91精品国产自产91精品| 午夜精品免费视频| 欧美精品videosex极品1| 中文字幕久久久av一区| 日韩综合视频在线观看| 欧美国产亚洲精品久久久8v| 欧美裸体xxxx| 亚洲国产精品大全| 国产美女扒开尿口久久久| 国产精品成av人在线视午夜片| 亚洲精品久久久久国产| 欧美黑人一级爽快片淫片高清| 精品国产自在精品国产浪潮| 成人精品一区二区三区| 91精品久久久久久久久久入口| 久久精品视频在线播放| 欧美国产极速在线| 丁香五六月婷婷久久激情| 国产亚洲精品久久久久久777| 久久精品国产久精国产一老狼| 啊v视频在线一区二区三区| 国产精品国产三级国产aⅴ9色| 亚洲高清一区二| 青青精品视频播放| 91精品国产色综合久久不卡98| xxxx性欧美| 国产欧美一区二区三区在线| 国自产精品手机在线观看视频| 日韩视频永久免费观看| 精品中文字幕在线| 亚洲片国产一区一级在线观看| 91精品久久久久久久久不口人| 97涩涩爰在线观看亚洲| 欧美日韩成人在线观看| 亚洲风情亚aⅴ在线发布| 91亚洲精品在线| 欧美精品videofree1080p| 欧美极品欧美精品欧美视频| 久久精品国产亚洲| 色爱av美腿丝袜综合粉嫩av| 欧美另类高清videos| 成人午夜在线观看| 日本欧美一二三区| 国色天香2019中文字幕在线观看| 51久久精品夜色国产麻豆| 亚洲精品久久久久久下一站| 日韩中文字幕精品| 国产欧美亚洲精品| 欧美性猛交xxxx| 中文字幕成人精品久久不卡| 久久91超碰青草是什么| 欧美色videos| 久久久久久久国产精品视频| 国语自产精品视频在线看抢先版图片| 91久久久久久久久久久久久| 欧美激情一区二区三区成人| 懂色aⅴ精品一区二区三区蜜月| 国产成人福利网站| 欧美视频一区二区三区…| 欧美视频国产精品| 欧美一级片在线播放| 国内精品久久影院| 97在线观看免费高清| 日本一区二区在线免费播放| 久久久综合免费视频| 国产精品pans私拍| 欧美成aaa人片在线观看蜜臀| 欧美在线激情网| 精品欧美一区二区三区| 国产国语videosex另类| 国产精品综合网站| 91精品国产精品| 亚洲人成啪啪网站| 日韩亚洲综合在线| 久久免费视频观看| 国产精品久久久久久久av大片| 中文字幕综合在线| 青青草原成人在线视频| 国产精品视频久久久久| 久久精品中文字幕免费mv| 亚洲欧美一区二区三区四区| 日韩av免费在线播放| 国产伦精品免费视频| 亚洲精品97久久| 久久伊人91精品综合网站| 91成人福利在线| 日韩免费av在线| 久久久久免费视频| 欧洲成人在线观看| 91在线观看免费观看| 狠狠色狠狠色综合日日五| 26uuu亚洲伊人春色| 欧美精品在线免费| 欧美精品videossex性护士| 久久久久久欧美| 亚洲国产精品久久91精品| 亚洲精品456在线播放狼人| 国产噜噜噜噜久久久久久久久| 亚洲成人久久一区| 国产精品欧美激情在线播放| 欧美在线精品免播放器视频| 亚洲第一二三四五区| 日韩精品视频免费在线观看| 中国人与牲禽动交精品| 国产999精品视频| 伊人男人综合视频网| 欧美在线视频免费观看| 色噜噜久久综合伊人一本| 在线视频免费一区二区| 欧美性xxxx极品hd欧美风情| 亚洲欧美精品在线| 国产欧美欧洲在线观看| 国产日韩欧美在线视频观看| 国产欧美日韩免费看aⅴ视频| 国产精品极品在线| 欧美一级高清免费| 国内精品久久久久伊人av| 亚洲精品aⅴ中文字幕乱码| 亚洲欧洲一区二区三区在线观看| 亚洲欧美另类自拍| 久久久久中文字幕2018| 96精品视频在线| 国产在线精品自拍| 国产精品丝袜一区二区三区| 亚洲欧美综合图区|