`
iflytek_wjzhu
  • 浏览: 41447 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
最近访客 更多访客>>
社区版块
存档分类
最新评论

Android日记之2012/02/15——随机不重复数

阅读更多
      今天在检查代码的时候,发现了一个关于含有不重复随机数的使用的陷阱。一开始在看代码的时候,并没有发现这个问题,但是Debug 的时候,就发现错了。其实,就是一个很浅显的问题,主要还是写给刚进入程序员这行的朋友。

      先把问题重现下,我们需要对0到15 的数字中取随机数,通过这个随机数,来保证在ValueList(为了和后面的ArrayList区分)中取到的值不重复。我并不清楚最早的做法是怎么写的,反正说是太损耗资源,就改用把ValueList中对应位置的值remove掉。觉得这样就能保证取到的值不重复了。

      对吗?错。为什么?因为,列表中的值remove掉了以后,并不是说当前的位置就空出来了,就比如说,一个列表中的位置是0、1、2、3,当我把2位置的值remove了以后,只是把3位置的值前移一格,对应的值还是0、1、2,不会变成0、1、3的。

      那对于这种取不重复随机数怎么做呢?

      我来说个我自己的做法。首先,创建一个ArrayList来存放随机数。当我从0到15的数字中取随机数的时候,我就把这个数字和ArrayList中存在的值比对一下,如果有则接着取下一个随机数,如果没有,就添加到ArrayList中。当我ArrayList的大小为15 的时候,我就不需要再添加值了,现在肯定是有0到15之间的15个不同额随机数了。那我再按照顺序从ArrayList中取这15个数出来,作为ValueList中值的对应位置在ValueList中取值。

      其实,这种随机数不重复还是有应用场合的。比如说,从一个题库中取出一批题目出来,那如何保证每次生成的题目的顺序不一样,同时,在一次做题序列中,保证题目是不重复的,就可以用到这种随机数不重复的List。

      当然,这只是我个人的做法,我也相信能有人比我用更有效的方法来实现这种随机数不重复(因为要比对前面存在的数字,所以要做循环,如果取的随机数比较多的话,我这种方法的效率比较低),大家不妨交流下。
0
0
分享到:
评论
2 楼 iflytek_wjzhu 2012-02-28  
黯然小伙 写道
我来说个我自己的做法。首先,创建一个ArrayList来存放随机数。当我从0到15的数字中取随机数的时候,我就把这个数字和ArrayList中存在的值比对一下,如果有则接着取下一个随机数,如果没有,就添加到ArrayList中。当我ArrayList的大小为15 的时候,我就不需要再添加值了,现在肯定是有0到15之间的15个不同额随机数了。那我再按照顺序从ArrayList中取这15个数出来,作为ValueList中值的对应位置在ValueList中取值。


这样的话如果运气不好的话,岂不是要随机很多次。没必要。随机下标就好了。。
//初始化
		List<Integer> list = new ArrayList<Integer>();
		for (int i = 1; i <= 15; i++) {
			list.add(i);
		}
		//不重复随机数
		for (int i = 0; i < 100; i++) {
			//随机下标
			int index = new Random().nextInt(list.size());
			//取出
			System.out.println(list.get(index));
			//删除
			list.remove(index);
			//判断是否取完
			if(list.isEmpty()){
				break;
			}
		}

嗯,自己写了一个Demo,看了下,理解了~~~谢谢,很不错的方法~~~
1 楼 黯然小伙 2012-02-24  
我来说个我自己的做法。首先,创建一个ArrayList来存放随机数。当我从0到15的数字中取随机数的时候,我就把这个数字和ArrayList中存在的值比对一下,如果有则接着取下一个随机数,如果没有,就添加到ArrayList中。当我ArrayList的大小为15 的时候,我就不需要再添加值了,现在肯定是有0到15之间的15个不同额随机数了。那我再按照顺序从ArrayList中取这15个数出来,作为ValueList中值的对应位置在ValueList中取值。


这样的话如果运气不好的话,岂不是要随机很多次。没必要。随机下标就好了。。
//初始化
		List<Integer> list = new ArrayList<Integer>();
		for (int i = 1; i <= 15; i++) {
			list.add(i);
		}
		//不重复随机数
		for (int i = 0; i < 100; i++) {
			//随机下标
			int index = new Random().nextInt(list.size());
			//取出
			System.out.println(list.get(index));
			//删除
			list.remove(index);
			//判断是否取完
			if(list.isEmpty()){
				break;
			}
		}

相关推荐

    android自定义效果——随机抽奖

    总的来说,实现"android自定义效果——随机抽奖"涉及的知识点包括:自定义视图的创建与绘制、Android动画机制(特别是`ObjectAnimator`)、随机数生成、触摸事件处理以及视图的优化。掌握这些技能,开发者可以创建出...

    安卓Android源码——随机验证码.zip

    安卓Android源码——随机验证码.zip

    Android学习笔记(十)——实现新闻列表

    Android学习笔记(一)——创建第一个Android项目 Android学习笔记(二)android studio基本控件及布局(实现图片查看器) Android学习笔记(三)android studio中CheckBox自定义样式(更换复选框左侧的勾选图像) ...

    C#开发Android应用实战——使用Mono for Android和.NET/C#(移动与嵌入式开发技术)完整版

    C#开发Android应用实战——使用Mono for Android和.NET/C#(移动与嵌入式开发技术)是一本很不错的书籍,但网上下载的多是不完整的。该版本是完整版。希望对大家有所帮助。

    AndroidStudio————实战演练——仿美团外卖菜单

    在本项目中,"AndroidStudio————实战演练——仿美团外卖菜单"是一个专注于使用Android Studio开发的应用程序实战案例,目标是创建一个类似于美团外卖的菜单功能。这个项目涵盖了多个Android开发的关键知识点,...

    MoodDiary——Android APP MoodDiary 日记APP

    MoodDiary是基于Java开发的Android日记APP,具有客户端和服务器两部分。前端使用Android Studio IDE 开发,后端使用Eclipse IDE开发。资源中附有客户端和服务器端所有源代码,另外还附有演示视频和设计文档,文档中...

    安卓Andriod源码——随机验证码.zip

    安卓Andriod源码——随机验证码.zip

    Android小项目——新闻APP(源码)

    Android小项目——新闻APP(源码),一个很简单的可以练手的Android Demo Ps:下载之前可以先看一下这篇文章——https://blog.csdn.net/qq_34149526/article/details/80992341

    Android实现记住用户名和密码功能

    https://github.com/GXS1225/Android————-.git 分析 (1)判断是否输入了账号和密码 if(name.trim().equals()){ Toast.makeText(this, 请您输入用户名!, Toast.LENGTH_SHORT).show(); return;

    黑马程序员——Android移动开发源码

    黑马程序员——Android移动开发源码

    Android——okhttp的封装

    Android——okhttp的封装,Android——okhttp的封装,Android——okhttp的封装,Android——okhttp的封装,Android——okhttp的封装

    Android代码-XModulable

    XModulable Latest Version SDK XModulable-api XModulable-compiler XModulable-annotation ...上层通过路由层查找组件/模块,通过组件/模块暴露的服务... android { defaultConfig { ... javaCompileOptions {

    android 9内置apk可卸载的问题

    —————————————————————————————- csdn博客看了许多,内置apk可卸载,总结起来三种。 第一种:说改android.mk, 放在data/app下面。 第二种:写一个脚本,开机的时候把目录复制到data/...

    基于Android的TCP服务端/客户端调试Demo

    Android TCP测试demo,包含apk和源码,支持十六进制发送接收,以太网和wifi的IP获取以及网线插拔监听,Android Things 1.0版本与Android 8.0均测试通过。WIFI和网线均可通信。可参看博文UI功能...

    Android 中文 API (19) —— TwoLineListItem

    ### Android 中文 API (19) —— TwoLineListItem #### 概述 在Android开发过程中,`TwoLineListItem`是一种常用的布局方式,主要用于显示具有两行文本的列表项。这种布局非常适合用来展示如联系人列表、消息...

    Android系统级深入开发——移植与调试 pdf

    《Android系统级深入开发——移植与调试》这本书深入探讨了Android系统的内部工作原理,涵盖了从系统移植到调试的全过程。在Android开发领域,系统级的深入理解是提升开发者能力的关键,下面将对其中的主要知识点...

    物联网智能插座 Android App部分——本科毕业设计项目源码.zip

    物联网智能插座 AndroidApp部分——本科毕业设计项目源码物联网智能插座 AndroidApp部分——本科毕业设计项目源码物联网智能插座 AndroidApp部分——本科毕业设计项目源码物联网智能插座 AndroidApp部分——本科毕业...

    【Android-数据存储】外部存储(存储在SD卡上)

    ———————————————————————————————————————— 1、向SD卡写数据 步骤: manifest中声明写权限: 请求权限:ActivityCompat.requestPermissions(this,new String[]{Manifest....

    移动操作系统原理与实践——基于Java语言的Android应用开发.zip

    移动操作系统原理与实践——基于Java语言的Android应用开发 目录 基础篇 第1章移动操作系统概论 1.1操作系统的原理与概念 1.1.1隐藏硬件细节 1.1.2资源管理 1.1.3操作系统的历史 1.2操作系统的分类 1.2.1...

    Android技术内幕.系统卷(扫描版)

    《android技术内幕:系统卷》 前言 第1章 准备工作 /1 1.1 深入认识android /2 1.1.1 android的系统构架 /2 1.1.2 android的初始化流程 /5 1.1.3 各个层次之间的相互关系 /8 1.1.4 android系统开发(移植)和应用...

Global site tag (gtag.js) - Google Analytics