java hashmap 随机_如何从Java中的HashMap中选择随机密钥?

小编典典

我设法找到一个解决方案,而不会降低性能。我将其张贴在这里,因为它可能对其他人有帮助-并可能回答有关此主题的几个未解决的问题(我将在以后搜索)。

您需要的是第二个Set类似于自定义的数据结构来存储密钥-

而不是此处建议的列表。类似于列表的数据结构要从中删除项目成本很高。所需的操作是在固定时间内添加/删除元素(以使其与HashMap保持最新),以及选择随机元素的过程。下面的类MySet正是这样做的

class MySet {

ArrayList contents = new ArrayList();

HashMap indices = new HashMap();

Random R = new Random();

//selects random element in constant time

A randomKey() {

return contents.get(R.nextInt(contents.size()));

}

//adds new element in constant time

void add(A a) {

indices.put(a,contents.size());

contents.add(a);

}

//removes element in constant time

void remove(A a) {

int index = indices.get(a);

contents.set(index,contents.get(contents.size()-1));

contents.remove(contents.size()-1);

indices.set(contents.get(contents.size()-1),index);

indices.remove(a);

}

}

2020-12-03

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值