文档章节

保证某些号码不重复 以及根据需要获取号码Utils

泉天下
 泉天下
发布于 2017/07/21 16:22
字数 383
阅读 3
收藏 0

 /**
      * 获取一定范围的随机数(已加同)
      * @param min
      * @param max
      * @param n
      * @param set1
      * @param list
      */
     public synchronized static void randomSet(int min, int max, int n, Set<Integer> set1,List<Integer> list) {  
         if (n > (max - min + 1) || max < min) {  
             return;  
         }  
         for (int i = 0; i < n; i++) {           
             /**
              * 返回指定范围的随机数(m-n之间)的公式但是取不到n
              * Math.random()*(n-m)+m;
              */
             int num = (int) (Math.random() * (max - min)) + min;  
             while (set1.contains(num)) {
                 num = (int) (Math.random() * (max - min)) + min;
             }
             set1.add(num);// 将不同的数存入HashSet中  
             list.add(num);
         }  
         int setSize = set1.size();  
         // 如果存入的数小于指定生成的个数,则调用递归再生成剩余个数的随机数,如此循环,直到达到指定大小  
         if (setSize < n) {  
          randomSet(min, max, n - setSize, set1,list);// 递归  
         }  
     }

       
       
     /**
      * 
      * @param n 要几个夺宝号
      * @param set1 保存数据库原有夺宝号
      * @param set1 保存本次执行的夺宝号
      */
     public synchronized static void orderSet(int n, Set<Integer> set,Set<Integer> set1) {  
         
         Integer j =  Collections.max(set);
         
         //循环获取指定夺宝号个数
         for(int i=0;i<n;i++){
             set1.add(++j);
         }
         
         //如果循环次数少于原有数据长度+所需夺宝号长度就再次循环获取夺宝号
         if(set.size()+set1.size()<set.size()+n){
             Integer g = Collections.max(set1);
             for(int i=0;i<(set.size()+n)-(set.size()+set1.size());i++){
                set1.add(++g);
             }
         }
         
     }

    /**
     * 截取字符串有[10001,10002,1003]截取成10001,10002,1003
     * @param set
     * @return
     */
    public static String subString(String set){
        return set.substring(set.indexOf("[")+1,set.indexOf("]"));
        
    }
     
       public static void main(String[] args) {
        HashSet<Integer> set = new HashSet<Integer>();
        set.add(1);
        HashSet<Integer> list = new HashSet<Integer>();
        
        //DuoBaoUtils.randomSet(1, 10, 1, set);
        
        DuoBaoUtils.orderSet(3, set, list);
        
        System.out.println("list:"+list.toString());
        System.out.println("list:"+DuoBaoUtils.subString(list.toString()));
        
        System.out.println("set:"+set.toString());
        System.out.println("list:"+DuoBaoUtils.subString(set.toString()));
    }

© 著作权归作者所有

共有 人打赏支持
泉天下
粉丝 1
博文 56
码字总数 33647
作品 0
广州
IOS 内置URL schemes简介

在IOS的应用中经常会看到一些应用程序通过某个点击动作而直接跳到App Store页面,开始很奇怪这种第三方应用于IOS的系统应用交互时怎么实现的。后来发现苹果的开发者文档中关于这种通信的实现...

big军
2013/03/16
0
2
android如何获取设备的唯一设备码

在某些项目中,需要记录用户的某些设置,或行为,并上传到服务器,如果无需用户登录注册,就可记录独立这些内容,就需要用到设备的某些独立的序列。(以下部分android需要API8以以上,andro...

卐字旗下的余晖
2013/12/18
0
0
使用信元流(TLVStream)规范、简化模块(C/C++)间交互

使用信元流(TLVStream)规范、简化模块(C/C++)间交互 收藏 问题描述: 在软件开发过程中,一般会对复杂的现实世界进行抽象,并且采用分而治之的策略,将大系统分解为子系统,将子系统分解...

晨曦之光
2012/06/06
75
0
CursorAdapter与CursorFilter机制

Android为ListView提供了Filter对象,对显示的条目进行过滤。最常见的用法就是Contact中,根据在输入框中输入姓名的字母显示过滤。当然android系统中默认提供的过滤功能非常有限,不支持号码...

长平狐
2012/10/09
99
0
一元购生成和分配幸运号码

一元购(一元夺宝)的实现思路是,用户使用1元钱购买某个固定价格的商品,每购买一次即可获得一个幸运号码,比如购买10元,则分配给用户10个幸运号码,当购买的额度达到商品的固定价格之后,...

别寒
2016/07/21
178
1

没有更多内容

加载失败,请刷新页面

加载更多

20.27 分发系统介绍~ 20.30 expect脚本传递参数

分发系统介绍分发系统-expect讲解(也就是一个分发的脚本)场景:业务越来越大,网站app,后端,编程语言是php,所以就需要配置lamp或者lnmp,最好还需要吧代码上传到服务器上;但是因...

洗香香
17分钟前
1
0
设计一个百万级的消息推送系统

前言 首先迟到的祝大家中秋快乐。 最近一周多没有更新了。其实我一直想憋一个大招,分享一些大家感兴趣的干货。 鉴于最近我个人的工作内容,于是利用这三天小长假憋了一个出来(其实是玩了两...

crossoverJie
23分钟前
1
0
软件架构:5种你应该知道的模式

Singleton(单例模式)、仓储模式(repository)、工厂模式(factory)、建造者模式(builder)、装饰模式(decorator)……大概每个上课听讲的程序员都不会陌生——软件的设计模式为我们提供...

好雨云帮
35分钟前
2
0
OSChina 周二乱弹 —— 这只是一笔金钱交易

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @小小编辑:推荐歌曲《暮春秋色》- 窦唯 / 译乐队 《暮春秋色》- 窦唯 / 译乐队 手机党少年们想听歌,请使劲儿戳(这里) @我没有抓狂:跨服聊...

小小编辑
47分钟前
405
14
df命令、du命令 、磁盘分区

9月25日任务 4.1 df命令 4.2 du命令 4.3/4.4 磁盘分区 4.1、命令 :df #磁盘空间使用情况 [root@zgxlinux-02 ~]# df 按字节显示 1000Byte=1KB 1000KB=1MB 1000MB=1GB ...

zgxlinux
55分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部