java抽奖程序

java抽奖程序,第1张

public String[] findluckMen(String[] data , int n){

Random random = new Random()

int len = data.length

String[] luckmen = new String[len]

for(int i=0i<亮缺咐敬纯扮帆leni++){

int index = random.nextInt(len)

luckmen[i] = data[index ]

}

return luckmen

}

抽取问题, 重点是 同一个学号不能重复被抽取.

解决办法很多,

比如数组可以使用下标来标记,号码是否被使用局高则,使用了就继续下一次抽桐棚取

也可以使用集合来抽取,把集合顺序打乱,然后随便抽几个就可以了

参考代码:数组法

import java.util.Random

public class Test {

public static void main(String[] args) {

int stuNums=30

int[] nums=new int[stuNums]//存储学号的数组

boolean[] flags=new boolean[stuNums]//标记,用于标记对应下标的学号是否已经被抽取过了

for (int i = 0 i < 念袜stuNums i++) {

nums[i]=i+1//给学号赋值

}

Random r=new Random()

while(true){

int index = r.nextInt(stuNums)

if(!flags[index]){

System.out.println("A等:"+nums[index])

flags[index]=true //标记已经被使用过了

break

}

}

for (int i = 0 i < 2 i++) {

int index = r.nextInt(stuNums)

if(!flags[index]){

System.out.println("B等:"+nums[index])

flags[index]=true

}else{

i--//如果已经被抽取过了 ,那么i建议,再次循环

}

}

for (int i = 0 i < 3 i++) {

int index = r.nextInt(stuNums)

if(!flags[index]){

System.out.println("c等:"+nums[index])

flags[index]=true

}else{

i--

}

}

}

}

集合法

import java.util.ArrayList

import java.util.Collections

public class Test2 {

public static void main(String[] args) {

int stuNums=20

ArrayList<Integer> list=new ArrayList<Integer>()

for (int i = 0 i < stuNums i++) {

list.add(i+1)

}

System.out.println("有序"+list)

Collections.shuffle(list)//打乱顺序

System.out.println("乱序"+list)

System.out.println("A等"+list.get(0))

System.out.println("B等"+list.get(1))

System.out.println("B等"+list.get(2))

System.out.println("C等"+list.get(3))

System.out.println("C等"+list.get(4))

System.out.println("C等"+list.get(5))

}

}

用一个Int[]数组记录随机到的数字,

插宴激代码:

int[] count=new i[6]/晌猜袜/用于接收生成的随机数

for(int i=0i<i.lengthi++)

{

Random rand = new Random()int c = rand.nextInt()//int范围类的随机数 c = rand.nextInt(30)//生成0-30以内的随机数 c = (int)(Math.random() * 30)//0-30以兆戚内的随机数 count[i]=c}


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12356048.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存