博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
生成8位随机不重复的数字编号
阅读量:6891 次
发布时间:2019-06-27

本文共 2479 字,大约阅读时间需要 8 分钟。

hot3.png

package com.jjinfo.common.util;      import java.util.Arrays;      import java.util.Random;            /**      *      */      public class RandomNumberGenerator {                /**          * 这是典型的随机洗牌算法。          * 流程是从备选数组中选择一个放入目标数组中,将选取的数组从备选数组移除(放至最后,并缩小选择区域)          * 算法时间复杂度O(n)          * @return 随机8为不重复数组          */          public static String generateNumber() {              String no="";              //初始化备选数组              int[] defaultNums = new int[10];              for (int i = 0; i < defaultNums.length; i++) {                  defaultNums[i] = i;              }                    Random random = new Random();              int[] nums = new int[LENGTH];              //默认数组中可以选择的部分长度              int canBeUsed = 10;              //填充目标数组              for (int i = 0; i < nums.length; i++) {                  //将随机选取的数字存入目标数组                  int index = random.nextInt(canBeUsed);                  nums[i] = defaultNums[index];                  //将已用过的数字扔到备选数组最后,并减小可选区域                  swap(index, canBeUsed - 1, defaultNums);                  canBeUsed--;              }              if (nums.length>0) {                  for (int i = 0; i < nums.length; i++) {                      no+=nums[i];                  }              }                    return no;          }          private static final int LENGTH = 8;                private static void swap(int i, int j, int[] nums) {              int temp = nums[i];              nums[i] = nums[j];              nums[j] = temp;          }                    public static String generateNumber2() {              String no="";              int num[]=new int[8];              int c=0;              for (int i = 0; i < 8; i++) {                  num[i] = new Random().nextInt(10);                  c = num[i];                  for (int j = 0; j < i; j++) {                      if (num[j] == c) {                          i--;                          break;                      }                  }              }              if (num.length>0) {                  for (int i = 0; i < num.length; i++) {                      no+=num[i];                  }              }              return no;          }                public static void main(String[] args) {              for (int i = 0; i < 10; i++) {      //            System.out.println(generateNumber());                  System.out.println(generateNumber2());              }          }      }

转载于:https://my.oschina.net/bluesroot/blog/222456

你可能感兴趣的文章
C语言结构体指针成员强制类型转换
查看>>
Mac下安装Caffe
查看>>
RDS-MSSQL问题排查方法
查看>>
实现u-boot对yaffs/yaffs2文件系统下载的支持
查看>>
git reset
查看>>
jsf开发心得(3)-jsf应用中css运用背景图片显示不了的问题
查看>>
IOS UIAlertController 弹出框中添加视图(例如日期选择器等等)
查看>>
ubuntu 12.04 开启root
查看>>
WAR包制作
查看>>
XSS
查看>>
Java 线程学习
查看>>
acl_cpp 编程之 xml 流式解析与创建
查看>>
基于域的无线安全认证方案
查看>>
Thread类常用方法
查看>>
我的友情链接
查看>>
几乎所有编程语言的hello, world程序(3)
查看>>
CentOs 设置静态IP 方法
查看>>
Windows上Python2.7安装Scrapy过程
查看>>
学习记录:浏览器JAVASCRIPT里的WINDOWS,DOCUMNET
查看>>
Nginx内置变量以及日志格式变量参数详解
查看>>