java双色球代码怎么编,java生成双色球不重复新手

Java双色球程序

我能理解你的思路,但做法有点小问题,这种做法就注定了不好判断是否重复,给你提供一种更好的思路

创新互联公司主要从事网页设计、PC网站建设(电脑版网站建设)、wap网站建设(手机版网站建设)、响应式网站开发、程序开发、网站优化、微网站、小程序定制开发等,凭借多年来在互联网的打拼,我们在互联网网站建设行业积累了丰富的网站建设、成都网站制作、网站设计、网络营销经验,集策划、开发、设计、营销、管理等多方位专业化运作于一体。

public static void main(String[] args) {

int a[]=new int [6];

int b=(int)(Math.random()*15+1);

// abcd:

// while(true){

// for(int i=0;ia.length;i++){

//     a[i]=(int)(Math.random()*35+1);//这里不要直接把随机出来的数放进数组,没法判断

// }

// for(int i=0;ia.length-1;i++){ //你是想在这里循环判断是否重复吧,思路是对的,

// //但过程太乱读不明白了,a.length为什么要-1

// for(int j=0;ja.length-1;j++){

// System.out.println(i);

// System.out.println(j);

// if(a[i]!=a[j]i!=jia.length){

// //问题在这,第一次循环i=0,j=0,没有问题

// //第二次循环i还=0,j=1了,那i肯定是不等j,所以必然break,根本没法判断

// System.out.println("----" + j);

// break abcd;

// }

// }

// }

// }

//下面是我给你提供的方法

int[] balls = new int[35];//创建一个有35个长度的数组作为选球池

for(int i=0;iballs.length;i++){

balls[i] = i + 1; //循环放入1至35

}

boolean[] used = new boolean[balls.length];//创建一个boolean数组,用于记录是否重复

//长度和球池等长

for(int i = 0;ia.length;i++){//循环向a数组中放入元素

for(;;){

int index = (int)(Math.random()*35);//生成一个随机数,这里不再+1了,因为随机的是下标,+1会出现越界

if(used[index]==true){ //如果used中,index的位置为true,则表示已经被随机过了

continue;//如果已经被随机过,则重新循环生成随机数

}

a[i] = balls[index];//如果没有被随机过,则将index所对应位置的元素放入a数组中

used[index] = true;//同时将该index位置设置为true,表示已经被随机过了

break;//退出当前循环,继续下一次向a中添加元素

}

}

for(int i=0;ia.length;i++){

for(int j=0;ja.length-1-i;j++){

if(a[j]a[j+1]){

int t=a[j];

a[j]=a[j+1];

a[j+1]=t;

}

}

}

// for(int i=0;ia.length;i++){

// System.out.println(a[i]);

// }//输出数组不需要这么麻烦

System.out.println(Arrays.toString(a));

System.out.println("蓝色球为"+b);

}

用java实现第二题的双色球程序,只求编写程序的思路,想自己写代码。求大神解答

int sum=(int) (Math.random()*33+1);  //利用Math中random方法的可以获得1~33的随机数

然后定义一个中奖的容器数组来装中奖数字

设置一个过滤器(for循环遍历中奖容器嵌套if语句)来防止红球中奖数字重复

也就是说双重for循环 外层取数,内层for循环过滤中奖数字,

在外层循环定义一个计数器来控制循环的结束

蓝球因为只有一次就不需要了

Java模拟生成双色球

public void main (String[] args){

int[] red=new int[7];

int blue=0;

for(int i=0;i7;i=i+1){

red[i]=getRandom(33);

//判断重复

while(true){

boolean needcheck=false;

for(int k=0;ki;k=k+1) { if(red[i]==red[k]){ needcheck=true; }}

if(needcheck){red[i]=red[i]+1; if(red[i]==34){red[i]=1}}else{break;}

}

//判断重复结束

}

//红球赋值结束

blue=getRandom(16);

System.out.println("生成的红球为:"+ red[0]+red[1]+red[2]+red[3]+red[4]+red[5]+red[6]);

System.out.println("生成的蓝球为:"+ );

}

public int getRandom(int Max){

return Math.floor(Math.random()*33)+1;

}

我刚刚初学java,怎么简单的编写双色球中奖程序阿,就是大概用数组,for循环,还有判断,编写出来

import java.util.Random;

public class PlayBall {

private int[] red = new int[6]; // 红色球

private int blue; // 蓝色球

// 开奖

public void open() {

Random random = new Random();// 随机数生成器,在java.util包里面

for (int i = 0; i  this.red.length; i++) {// 生成红球

// random.nextInt(int);这个方法用于随机生成一个整数,范围在0-int之间

this.red[i] = random.nextInt(32) + 1;

}

// 蓝色球的取值范围是1-16,调用nextInt(15)会生成一个0-15直接的数,再加个1就是1-16了

this.blue = random.nextInt(15) + 1;

// 输出开奖情况

for (int i = 0; i  this.red.length; i++) {

System.out.print(this.red[i] + "\t");

}

System.out.println("\r\n" + this.blue);

}

// 中奖,传入号码,匹配是否中奖,如果中奖返回中的几等奖,没总返回-1

public int isMiddle(int[] red,int blue) {

// 输出投注号码

for (int i = 0; i  red.length; i++) {

System.out.print(red[i] + "\t");

}

System.out.println("\r\n" + blue);

int middle = 0;// 记录中了几个球

if (blue == this.blue) {

middle += 1;// 蓝色球中

}

for (int i = 0; i  red.length; i++) {

if (red[i] == this.red[i]) {

middle += 1;// 红色球中

}

}

if (middle != 0) {

if (middle  4) {

return 6;

}

else if (middle == 4) {

return 5;

}

else if (middle == 5) {

return 4;

}

else if (middle == 6) {

// 中6个球有两种情况,5+1和6+0,5+1是三等奖,6+0是二等奖

if (blue == this.blue) {

return 2;// 6+0中二等奖

}

return 3;

}

else if (middle == 7) {

return 1;

}

}

// 没中奖

return -1;

}

// 测试

public static void main(String[] args) {

PlayBall pb = new PlayBall();

pb.open();

System.out.println("中奖:" + pb.isMiddle(new int[] { 1, 2, 3, 4, 5, 6 }, 5));

}

}

回答个问题我还得去研究双色球怎么中奖的。。。这个代码编译一下就可以直接运行了


网页名称:java双色球代码怎么编,java生成双色球不重复新手
分享网址:http://ybzwz.com/article/hssshi.html