[i]本博文属于原创,转载请注明来源即可[/i]
双色球分为1~36选择6个数字为红色球1~16选择1个数字为蓝色球,构成双色球,没买过,也不是很清楚,但是按照规则能写程序就行了!
红色球和蓝色球,都不能内部重复,也就是不能出现相同的数字;
红色球范围1~37
蓝色球范围1~16
输出5组不重复的双色球,并打印出来、

这时一家面试题,代码如下

Ball 双色球实体类

package cn.com;

import java.util.Hashtable;import java.util.Iterator;import java.util.Set;

public class Ball {

 private Hashtable redBalls;   private int blueBall;

   public int getBlueBall() {        return blueBall;  }

   public void setBlueBall(int blueBall) {       this.blueBall = blueBall;    }

   /**    * 重写equals方法,判断传进来的对象和this对象是否一样   */   @Override    public boolean equals(Object obj) {       // 把obj对象转换为当前对象      Ball eqBall = (Ball) obj;        // 对比蓝色球,如果蓝色球不一样,则就返回false;        if (eqBall.getBlueBall() != this.getBlueBall()) {            return false;     }     // 判断红色球,需从hashTable中拿出来对比     Hashtable eqRedBalls = eqBall.getRedBalls();

       Set set1 = eqRedBalls.keySet();      Iterator it = set1.iterator();       while (it.hasNext()) {            // 按照顺序拿出值来,看是否存在this.getRedBalls中,如果不存在,直接返回true            if (!this.getRedBalls().containsKey(it.next())) {             return false;         } else {              continue;         }     }     return true;  }

   /**    * 重写toString 方法,输出红色球和蓝色球  */   @Override    public String toString() {        StringBuffer sb = new StringBuffer();        if (redBalls.size() != 6) {          sb.append("双色球错误");     } else {          sb.append("红色球为:");          Set set2 = redBalls.keySet();            Iterator it = set2.iterator();           while (it.hasNext()) {                sb.append(" " + redBalls.get(it.next()) + " ");         }         sb.append("蓝色球:" + blueBall);       }     return sb.toString(); }

   public Hashtable getRedBalls() {      return redBalls;  }

   public void setRedBalls(Hashtable redBalls) {     this.redBalls = redBalls;    }

}

随即创建Ball类service

package cn.com;

import java.util.Hashtable;//随即产生双色球和蓝色球,本应用到了随机数,求余public class Service {    /**    * 随即创建一个双色球   * @return    */   public Ball creatBall() {     Hashtable ht = new Hashtable<Integer, Integer>();      int blueNum;      int redNum;       Ball ball = new Ball();      blueNum = (int) (Math.random() * 100) % 16 + 1;//       System.out.println(blueNum);      // 获取6个红色球        while (true) {            if (ht.size() < 6) {               redNum = (int) (Math.random() * 100) % 36 + 1;              if (redNum == blueNum) {                    continue;             } else {                  if (ht.containsKey(redNum)) {                     continue;                 } else {                      ht.put(redNum, redNum);                   }             }         }else{                break;            }     }     ball.setBlueBall(blueNum);        ball.setRedBalls(ht);     return ball;  }}

测试类 test.java

package cn.com;

import java.util.ArrayList;import java.util.Hashtable;import java.util.List;

public class Test {

   /**    * 测试实体类的tostring方法和equals方法   */   public void test_toStringAndEquals() {        Hashtable t1 = new Hashtable<Integer, Integer>();      t1.put(1, 1);     t1.put(2, 2);     t1.put(3, 3);     t1.put(4, 4);     t1.put(5, 5);     Ball b1 = new Ball();        b1.setRedBalls(t1);       b1.setBlueBall(3);        Hashtable t2 = new Hashtable<Integer, Integer>();      t2.put(1, 1);     t2.put(2, 2);     t2.put(3, 3);     t2.put(4, 4);     t2.put(6, 6);     Ball b2 = new Ball();        b2.setRedBalls(t2);       b2.setBlueBall(3);        System.out.println(b2.equals(b1));        System.out.println(b1);       System.out.println(b2);   }

   public static void main(String[] args) {//        Hashtable ht=new Hashtable<K, V>       Service s=new Service();     List<Ball> list=new ArrayList<Ball>();       while(list.size()<5){          //创建一个Ball实例          Ball ball=s.creatBall();         //和list里面的每个Ball对比,看是否有相同的,如果有相同的,则不添加进去,否则就添加进去          boolean flag=false;//表示是否存在相同的,默认为false,表示不存在          for (int i = 0; i < list.size(); i++) {             Ball eqBall=list.get(i);             if(ball.equals(eqBall)){                  flag=true;                   break;                }             continue;         }         if(flag){             continue;         }else{                list.add(ball);           }         }

       for(int i=0;i<list.size();i++){         Ball ball=list.get(i);           System.out.println(ball);     }

 }

}

运行结果:

红色球为: 9 31 19 3 24 13 蓝色球:8
红色球为: 20 7 18 5 25 1 蓝色球:14
红色球为: 10 19 4 25 1 22 蓝色球:2
红色球为: 10 29 17 4 13 23 蓝色球:14
红色球为: 21 30 18 28 16 2 蓝色球:14

[i]本博文属于原创,转载请注明来源即可7[/i]

提供源码打包下载

按照规则输出5组不重复的双色球(6个红色球+1个蓝色球)相关推荐

  1. sont表示元素在存入集合时进行了排序,数据遍历的结果是按某个排序规则输出的

    单选 sont表示元素在存入集合时进行了排序,数据遍历的结果是按某个排序规则输出的;而order表示每次遍历的序列都是一样的,元素前后关系每次遍历都是确定的,那么下列哪些集合既是sort,又是orde ...

  2. 2-数组中重复的数字

    2-数组中重复的数字 一.问题描述: 找出数组中重复的数字 在一个长度为n的数组里的所有数字都在0~n-1的范围内,数组中某些数字是重复的,但不知道有几个数字重复,也不知道重复了几次.请找出数组中任意 ...

  3. 剑指Offer-数组中重复的数字

    题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一个重复的数字. 例如,如果输入长度为 ...

  4. PTA6、输出10个不重复的英文字母 (10 分)

    6.输出10个不重复的英文字母 (10 分) 随机输入一个字符串,把最左边的10个不重复的英文字母(不区分大小写)挑选出来. 如没有10个英文字母,显示信息"not found" ...

  5. 下面的程序可以从0....n-1中随机等概率的输出m个不重复的数。(假设nm)

    问题:题目下面的程序可以从0....n-1中随机等概率的输出m个不重复的数.这里我们假设n远大于m. 括号里应填写什么? ....... knuth(int n, int m) {      sran ...

  6. 如何输入多组数据并输出每组数据的和?

    如何输入多组数据? 下面我分三种语言讲解这个问题 1. C语言 先讲解一下scanf的返回值,假设说scanf读入一个数字或者字符并成功.例如:scanf("%d, &x),那么返回 ...

  7. 请写代码校验第二代身份证号码有效性。程序接收一个18位的身份证号码和性别,根据以下规则输出号码是有效还是无效。

    请写代码校验第二代身份证号码有效性.程序接收一个18位的身份证号码和性别,根据以下规则输出号码是有效还是无效. 第二代身份证号组成规则: a) 身份证号码(18位)= 地址码(6)+ 出生日期码(8) ...

  8. 双色球规则:双色球每注投注号码由6个红色球号码和1个蓝色球号码组成。红色球从1—33中随机生成6个不重复的号码;蓝色球号码从1—16中随机生成1个;客户通过键盘录入购买的红色球6个(不重复)和蓝色

    双色球规则:双色球每注投注号码由6个红色球号码和1个蓝色球号码组成. 红色球从1-33中随机生成6个不重复的号码:蓝色球号码从1-16中随机生成1个: 客户通过键盘录入购买的红色球6个(不重复)和蓝色 ...

  9. Python练习——输出10个不重复的英文字母

    Python练习--输出10个不重复的英文字母 随机输入一个字符串,把最左边的10个不重复的英文字母(不区分大小写)挑选出来. 如没有10个英文字母,显示信息"not found" ...

最新文章

  1. 如何在电脑上创建python_python怎么创建类Python中的除法
  2. 在Visual Studio 2010/2012中 找不到创建WebService的项目模板
  3. 数据库系统概念总结:第五章 高级SQL
  4. 10大申请攻略+套磁技巧助你完胜美研申请
  5. NYOJ 229 工程 二分+dp检验
  6. CSS 选择器 :last-child与:last-of-type的区别
  7. #51CTO学院四周年# 还好没放弃,终于等到你~
  8. 《朝花夕拾》金句摘抄(三)
  9. leetcode: 451. Sort Characters By Frequency
  10. canvas转盘转动?
  11. Money 20/20 | 未来金融数字化转型:数字化半径与全栈式战略观
  12. ajax连接mysql数据库查询数据_ajax动态查询数据库数据并显示在前台的方法
  13. [转]find命令之exec
  14. 企业申请CMMI3-CMMI5必经的六个阶段
  15. 常用矢量图有哪些格式?AI文件存储为psd分层
  16. Java B组蓝桥杯第十届国赛:大胖子走迷宫
  17. 猜拳小游戏编程(python)
  18. c语言综合合计实验报告,C语言设计实验报告(第一次)
  19. 做自媒体1年投资4百W亏损370W,自媒体的水太深
  20. iOS 玩转微信——通讯录

热门文章

  1. 动规之-分组背包问题
  2. PI染料|PI (碘化丙啶, Propidium Iodide)嵌入双链DNA后释放红色荧光
  3. 疫情期间如何找一份更好的工作?
  4. 如何成为一名合格的php程序员
  5. CAD、3dmax、Maya、Revit安装过程中显示产品已安装,如何卸载干净?
  6. USB系列:列出你的USB设备
  7. 影视解说怎么做?超详细教程分享给大家
  8. java while循环 计算机,java中如何利用while循环求n的阶乘
  9. 培养情商,现在也不晚
  10. 算法强化每日一题--组队竞赛