每日一记--2014.9.12

今天是整数随机置换

还有记住:java中的基本数据类型是传递值的而不是传递引用的

 1 package 随机置换;
 2 import java.util.*;
 3 
 4 //生成前N个整数的随机置换
 5 //先顺序填满整个数组,然后挨个和前面的随机任取的位置交换
 6 
 7 public class RandomExchange {
 8 
 9     public static void main(String[] args) {
10         // TODO Auto-generated method stub
11        int[] a= suijizhihuan(6);
12        for(int i=0;i<a.length;i++){
13         System.out.print(a[i]+",");
14         }
15     }
16     
17     private static int[] suijizhihuan(int n){
18         int[] suiji =new int[n];
19         for(int i=0;i<n;i++){
20             suiji[i]=i+1;
21         }
22         Random ran =new Random();
23         //i要从1开始!!!
24         for(int i=1;i<n;i++){
25             swap(suiji,i,ran.nextInt(i));
26         }
27         return suiji;
28         
29     }
30     //直接int temp=a;a=b;b=temp;的swap函数是不行的
31     //因为在java中的基本数据类型是传递值的而不是传递引用的
32     //所以如果有数组,可以这样写swap函数
33     private static void swap(int [] arr,int i ,int j){
34         int temp = arr[i];
35         arr[i]=arr[j];
36         arr[j]=temp;
37         
38     }
39 
40 }

 

posted @ 2014-09-12 21:49  ivywenyuan  阅读(143)  评论(0编辑  收藏  举报