码迷,mamicode.com
首页 > 其他好文 > 详细

实用的随机数生成类Random:测试(随机产生100个不重复的正整数)

时间:2017-05-12 20:28:39      阅读:269      评论:0      收藏:0      [点我收藏+]

标签:分解   大于   public   omd   种子   控制   客户   int   stat   

实用的随机数生成类Random:测试(使用Random类随机生成100个不重复的正整数)

一、之前我们使用随机数用的是Math类的random()方法:

tips:

产生随机数(0~9中任意整数)的方法:int random = (int)(Math.random()*10);

1.商场幸运抽奖程序。

会员号的百位数字等于产生的随机数即为幸运会员。

 

public class GoodLuck{

  public static void main(String[] args){

    //产生随机数

    int random = (int)(Math.random()*10);

    //从控制台接收一个4位会员号

    System.out.println("我行我素购物管理系统>幸运抽奖\n");

    System.out.print("请输入4位会员号:");

    Scanner input = new Scanner(System.in);

    int custNo = input.nextInt();

    //分解获得百位

    int baiwei = custNo/100%10;

    //判断是否是会员

    if(baiwei = random){

      System.out.println(custNo+"是幸运客户,获精美MP3一个。");

    }else{

      System.out.println(custNo+"谢谢您的支持!");

    }

  }

}

二、其实,Math类的random方法的底层就是使用Random类实现的。

1.给构造方法有两种重载方法:

Random();

创建一个新的随机数生成器。

Random(long seed);

使用单个long种子创建一个新的随机数生成器。

tips:

如果用同样一个种子值来初始化两个Random对象,然后用每个对象调用相同的方法,那么得到的随机数也是相同的(令牌)

2.返回下一个伪随机数的方法:

int nextInt();

返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的int值。

int nextInt(int n);

返回下一个伪随机数,它是取自此随机数生成器序列的,在0(包括)和指定值(不包括)之间均匀分布的int值。

三、Random类的使用

1.随机生成20个10以内大于或等于0的整数,并将其显示出来:

import java.util.Random;

public class RandomDemo{

  public static void main(String[] args){

    //创建一个Random对象

    Random rand = new Random();

    //随机生成20个随机整数,并显示

    for(){

      int num = rand.nextInt(10);

      System.out.println("第"+(i+1)+"个随机数是:"+num);

    }

  }

}

2.案例:随机产生100个不重复的整数

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashSet;
import java.util.List;
import java.util.Random;
import java.util.Set;

/**
 * 随机生成100个不重复的随机数
 * @author Administrator
 *
 */
public class RandomDemo {
	
	public static void main(String[] args) throws ParseException {
		Random rand = new Random();
		System.out.println("Set方法:");
		//Set集合保存
		Set<Integer> nums = new HashSet<Integer>();
		//循环保存
		do{
			nums.add(rand.nextInt(100));
		}while(nums.size()<100);
		for (Integer num : nums) {
			System.out.println(num);
		}
		System.out.println("List方法:");
		//List集合保存
		List<Integer> list = new ArrayList<Integer>();
		int num;
		do{
			num = rand.nextInt(100);
			for (Integer item : list) {
				if (num==item) {
					continue;
				}
			}
			list.add(num);
		}while(list.size()<100);
		for (Integer item : list) {
			System.out.println(item);
		}
		/*Date类的使用*/
		//日期格式
		Date date = new Date();
		SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 24小时HH:mm:ss 12小时hh:mm:ss");
		SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd");
		System.out.println("当前时间:"+sdf.format(date));
		String str = "2016-12-31";
		Calendar calendar = Calendar.getInstance();
		date = sdf1.parse(str);
		calendar.setTime(date);
		System.out.println(calendar.get(Calendar.YEAR));
	}

}

  

实用的随机数生成类Random:测试(随机产生100个不重复的正整数)

标签:分解   大于   public   omd   种子   控制   客户   int   stat   

原文地址:http://www.cnblogs.com/tengqiuyu/p/6846930.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!