随机获取一个集合(List, Set)中的元素,随机获取一个Map中的key或value

利用Java提供的Random类。从List或Set中随机取出一个元素,从Map中随机获取一个key或value。

因为Set没有提供get(int index)方法,仅仅能先获取一个随机数后。利用一个计数器,对Set进行循环,当计数器等于随机数时返回当前元素,对于Map的处理也类似。

不知有没有更好的方法……

package com.xjj.util;

import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ThreadLocalRandom;

/**
 * 随机数工具,单例模式
 * @author XuJijun
 *
 */
public class RandomUtils {
	//private static Random random;

	//双重校验锁获取一个Random单例
	public static ThreadLocalRandom getRandom() {
		return ThreadLocalRandom.current();
		/*if(random==null){
			synchronized (RandomUtils.class) {
				if(random==null){
					random =new Random();
				}
			}
		}

		return random;*/
	}

	/**
	 * 获得一个[0,max)之间的随机整数。
	 * @param max
	 * @return
	 */
	public static int getRandomInt(int max) {
		return getRandom().nextInt(max);
	}

	/**
	 * 获得一个[min, max]之间的随机整数
	 * @param min
	 * @param max
	 * @return
	 */
	public static int getRandomInt(int min, int max) {
		return getRandom().nextInt(max-min+1) + min;
	}

	/**
	 * 获得一个[0,max)之间的长整数。
	 * @param max
	 * @return
	 */
	public static long getRandomLong(long max) {
		return getRandom().nextLong(max);
	}

	/**
	 * 从数组中随机获取一个元素
	 * @param array
	 * @return
	 */
	public static <E> E getRandomElement(E[] array){
		return array[getRandomInt(array.length)];
	}

	/**
	 * 从list中随机取得一个元素
	 * @param list
	 * @return
	 */
	public static <E> E getRandomElement(List<E> list){
		return list.get(getRandomInt(list.size()));
	}

	/**
	 * 从set中随机取得一个元素
	 * @param set
	 * @return
	 */
	public static <E> E getRandomElement(Set<E> set){
		int rn = getRandomInt(set.size());
		int i = 0;
		for (E e : set) {
			if(i==rn){
				return e;
			}
			i++;
		}
		return null;
	}

	/**
	 * 从map中随机取得一个key
	 * @param map
	 * @return
	 */
	public static <K, V> K getRandomKeyFromMap(Map<K, V> map) {
		int rn = getRandomInt(map.size());
		int i = 0;
		for (K key : map.keySet()) {
			if(i==rn){
				return key;
			}
			i++;
		}
		return null;
	}

	/**
	 * 从map中随机取得一个value
	 * @param map
	 * @return
	 */
	public static <K, V> V getRandomValueFromMap(Map<K, V> map) {
		int rn = getRandomInt(map.size());
		int i = 0;
		for (V value : map.values()) {
			if(i==rn){
				return value;
			}
			i++;
		}
		return null;
	}

	/**
	 * 生成一个n位的随机数,用于验证码等
	 * @param n
	 * @return
	 */
	public static String getRandNumber(int n) {
		String rn = "";
		if (n > 0 && n < 10) {
			//Random r = new Random();
			StringBuffer str = new StringBuffer();
			for (int i = 0; i < n; i++) {
				str.append(‘9‘);
			}
			int num = Integer.parseInt(str.toString());
			while (rn.length() < n) {
				rn = String.valueOf(ThreadLocalRandom.current().nextInt(num));
			}
		} else {
			rn = "0";
		}
		return rn;
	}

	public static void main(String[] args) {
		/*Set<String> set = new HashSet<>();
		for (int i = 0; i < 12; i++) {
			set.add("I am: " + i);
		}

		for (int i = 0; i < 10; i++) {
			System.out.println(getRandomElement(set));
		}*/

		System.out.println(getRandom().nextInt(-100, 10));
	}
}
时间: 2024-12-18 07:32:23

随机获取一个集合(List, Set)中的元素,随机获取一个Map中的key或value的相关文章

写一个函数实现数组中的元素随机乱序排序

//原生JS写一个函数实现一个shuffle方法,将数组中的元素随机乱序排序 var shuffle = function(arr){ var len,t,rand; for(var i =0;len = arr.length,i<len;i++){ rand = parseInt(Math.random()*len);//parseInt(Math.random()*(len-1-0)+1);或者rand = Math.floor(Math.random()*(len-1-0)+1);即Mat

如何将一个数组中的元素插入另一个数组

如何将一个数组中的元素插入另一个数组:本章节直接给出一段将一个数组中元素插入另一个数组中的代码实例,直接套用就可以了.代码如下: var first = ['a','b','c']; var second = ['1','2','3']; var index = 1; second.unshift(index, 0); Array.prototype.splice.apply(first, second); 原文地址是:http://www.softwhy.com/forum.php?mod=v

用最小的空间复杂度找出一个长度为n的数组且数据中的元素是[0,n-1]中任一个重复的数据。

比如:[1, 2, 3, 3, 2, 2, 6, 7, 8, 9] 中 2 or 3 分析:这道题目,实现比较容易,方法也不少,但要用最小的空间复杂度来看的话, 和充分考虑一下数据的下标和数据元素值的特点,比如如果把第 i 个位置放的值是 i,不是的情况做交换,去循环对比. 时间复杂度O(n),空间复杂度可到常量级 测试代码如下: public static void main(String[] args) { int n=10; List<Integer> list = new ArrayL

Java中让fastJson识别Colloction和Map中的泛型类

由于fastJson的高效性,最近采用fastJson来做序列化并存储数据,但出现了一个麻烦的问题,如果将Map<K,V>这样的类型序列化,反序列化就会不尽人意,有以下尝试: 使用JSON.parseObject(json):得到的结果是无类型Map,其value为JSONObject. 使用JSON.parseObject(json, Map.class):结果同上. 虽然说使用JSONObject.toJavaObject(V.class)也能够完成所求,但是这样的方法还是略麻烦,而且如果

golang中的slice翻转存在以及map中的key判断

//slice翻转 func stringReverse(src []string){ if src == nil { panic(fmt.Errorf("the src can't be empty!")) } count := len(src) mid := count/2 for i := 0;i < mid; i++{ tmp := src[i] src[i] = src[count-1] src[count-1] = tmp count-- } } //判断是否包含 f

向值栈获取List集合

-------------------siwuxie095 从值栈获取 List 集合 1.具体步骤 (1)在 Action 中向值栈放 List 集合 (2)在 JSP 页面中从值栈获取 List 集合 2.具体实现 (1)编写实体类 User.java: package com.siwuxie095.entity; // User 实体类 public class User { private String username; private String password; private

去除List集合中的重复元素? 如果没有Set集合,List集合是怎么去除重复元素的(字符串类型,自定义类型)?

 关键字: 如果没有Set集合,List集合是怎么去除重复元素的(字符串类型)?  *   *     思考: List就可以存储重复元素,那么需求中容器中的元素必须保证唯一性,该如何解决呢??  *      *   去除List集合中的重复元素?  * * 思路: * * 1.首先我需要另一个临时容器tempList,用来存放我认为应该保留的元素.(也就是不重复的元素) * 2.然后我们应该遍历原容器, 一个一个的取出元素, 放入tempList. * 当tempList里已经装有刚刚取出的

C/C++中变量的分配和在内存中的存储方式

操作系统与C语言中的堆栈及其区别 CSDN C/C++ 一个由C/C++编译的程序占用的内存分为以下几个部分 1. 栈区(stack)- 由编译器自动分配释放,存放函数的参数名,局部变量的名等.其操作方式类似于数据结构中的栈. 2. 堆区(heap)- 由程序员分配释放,若程序员不释放,程序结束时可能由OS回收.注意它与数据结构中的堆是两回事,分配方式倒是类似于链表. 3. 全局区(静态区)(static)-全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的

JavaScript 的in 操作符 (“如何判断某值是否数组中的元素”?)

在编写JavaScript时,遇到一个常见的问题"如何判断某值是否数组中的元素"?这让我想起了PHP中的in_array()函数和Python中in 操作符.但JavaScript似乎没有内置类似的函数,而其in 操作符的作用也有点不同.通过查询相关的资料,我发现JavaScript的in 操作符还是挺有用的. 一.问题让我想到in 操作符,正是因为这样一个问题:"如何判断某值是否数组中的元素"?在PHP中,您可能会这样来处理: $os = array("

删除Map中Value重复的记录,并且只保留Key最小的那条记录

介绍 晚上无聊的时候,我做了一个测试题,测试题的大体意思是:删除Map中Value重复的记录,并且只保留Key最小的那条记录. 例如: I have a map with duplicate values: ("A", "1"); ("B", "2"); ("C", "2"); ("D", "3"); ("E", "3