实用的随机数生成类Random:测试(随机产生100个不重复的正整数)
实用的随机数生成类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个不重复的正整数)的更多相关文章
- 随机数生成类Random用法
一.构造方法: Random() 创建一个新的随机数生成器. Random(long seed) 使用单个 long 种子创建一个新的随机数生成器. 无参构造方 ...
- 类 Random
什么是Random类 此类的实例用于生成伪随机数 Random使用步骤 查看类 java.util.Random :该类需要 import导入使后使用. 查看构造方法 public Random() ...
- 随机数类Random
我们来学习下,用来产生随机数的类Random,它也属于引用数据类型. 这个Random类,它可以产生多种数据类型的随机数,在这里我们主要介绍生成整数与小数的方式. l 方法简介 public int ...
- 随机数类 Random
import java.util.Random; /* 随机数类 Random 需求: 编写一个函数随机产生四位的验证码. */ public class Demo5 { public static ...
- Java基础-继承-编写一个Java应用程序,设计一个汽车类Vehicle,包含的属性有车轮个数 wheels和车重weight。小车类Car是Vehicle的子类,其中包含的属性有载人数 loader。卡车类Truck是Car类的子类,其中包含的属性有载重量payload。每个 类都有构造方法和输出相关数据的方法。最后,写一个测试类来测试这些类的功 能。
#29.编写一个Java应用程序,设计一个汽车类Vehicle,包含的属性有车轮个数 wheels和车重weight.小车类Car是Vehicle的子类,其中包含的属性有载人数 loader.卡车类T ...
- 实现如下类之间的继承关系,并编写Music类来测试这些类。
实现如下类之间的继承关系,并编写Music类来测试这些类. package com.hanqi.test; public class Instrument { //输出弹奏乐器 public void ...
- IO流,File类的测试........课堂加总结
package liu0926; import java.io.File; import java.io.IOException; public class Text01 { public stati ...
- 简单练习题2编写Java应用程序。首先定义一个描述银行账户的Account类,包括成员变 量“账号”和“存款余额”,成员方法有“存款”、“取款”和“余额查询”。其次, 编写一个主类,在主类中测试Account类的功能
编写Java应用程序.首先定义一个描述银行账户的Account类,包括成员变 量“账号”和“存款余额”,成员方法有“存款”.“取款”和“余额查询”.其次, 编写一个主类,在主类中测试Account类的 ...
- mongoDB工具类以及测试类【java】
java操作mongo工具类 package Utils; import com.mongodb.MongoClient; import com.mongodb.MongoCredential; im ...
随机推荐
- 【bzoj2330】: [SCOI2011]糖果 图论-差分约束-SPFA
[bzoj2330]: [SCOI2011]糖果 恩..就是裸的差分约束.. x=1 -> (A,B,0) (B,A,0) x=2 -> (A,B,1) [这个情况加个A==B无解的要特 ...
- IIS发布ASP程序问题汇总
看异常位置,因为域的问题
- 洛谷P2754 [CTSC1999]家园(最大流)
传送门 这题思路太强了……大佬们怎么想到的……我这菜鸡根本想不出来…… 先判断是否能到达,对每一艘飞船能到的地方用并查集合并一下,最后判断一下是否连通 然后考虑几天怎么判断,我们可以枚举. 每一个点表 ...
- C#基于SQLiteHelper类似SqlHelper类实现存取Sqlite数据库的方法
本文实例讲述了C#基于SQLiteHelper类似SqlHelper类实现存取Sqlite数据库的方法.分享给大家供大家参考.具体如下: 这个类不是我实现的,英文原文地址为http://www.egg ...
- JUC包下CyclicBarrier学习笔记
CyclicBarrier,一个同步辅助类,在API中是这么介绍的: 它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这 ...
- get请求和post的请求的区别
https://www.cnblogs.com/logsharing/p/8448446.html
- 洛谷 P3182 [HAOI2016]放棋子(错排问题)
题面 luogu 题解 裸的错排问题 错排问题 百度百科:\(n\)个有序的元素应有\(n!\)个不同的排列,如若一个排列使得所有的元素不在原来的位置上,则称这个排列为错排:有的叫重排.如,1 2的错 ...
- ASP.NET 设计模式分为三种类型
设计模式分为三种类型,共23类. 一.创建型模式:单例模式.抽象工厂模式.建造者模式.工厂模式.原型模式. 二.结构型模式:适配器模式.桥接模式.装饰模式.组合模式.外观模式.享元模式.代 ...
- BFS和图的最短路径 279,127,126
在本题中,任何一个正整数都会由完全平方数1组成,所以不可能没有解. 贪心是不成立的,因为如果寻找12的完全平方数,使用贪心,则它由9,1,1,1四个数组成:但是最少的完全平方数是由三个4组成的. 4- ...
- hdu3966 Aragorn's Story 树链剖分
题目传送门 题目大意: 有n个兵营形成一棵树,给出q次操作,每一次操作可以使两个兵营之间的所有兵营的人数增加或者减少同一个数目,每次查询输出某一个兵营的人数. 思路: 树链剖分模板题,讲一下树链剖分过 ...