/**
*
*/
public class f {
public static void main(String args[]){
Scanner scan = new Scanner(System.in)
System.out.print("请输入抽奖号码上限:")
渣卖蔽 int max = scan.nextInt()
System.out.print("请输入抽奖次数:"配碧)
int n = scan.nextInt()
System.out.print("中奖号码依次为:")
for(int i=0i<ni++){
System.out.print((int)(Math.random()*max+1)+" ")
如州 }
}
}
抽取问题, 重点是 同一个学号不能重复被抽取.
解决办法很多,
比如数组可以使用下标来标记,号码是否被使用局高则,使用了就继续下一次抽桐棚取
也可以使用集合来抽取,把集合顺序打乱,然后随便抽几个就可以了
参考代码:数组法
import java.util.Randompublic 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.ArrayListimport 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}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)