//写一个生成彩票号码的小程序,[1,33]之间(包含1和33)随机选七个不重复的数字 //并把生成的彩票号码打印在控制台上。 //解析用到的知识点有: //数组 //生成随机数 //循环语句 //条件判断语句(注:7个数字不能重复)Java要简单点的
时间: 2023-09-16 17:15:04 浏览: 209
以下是Java代码实现:
```java
import java.util.Arrays;
import java.util.Random;
public class LotteryGenerator {
public static void main(String[] args) {
int[] lottery = new int[7];
Random random = new Random();
for (int i = 0; i < 7; i++) {
int num;
do {
num = random.nextInt(33) + 1;
} while (contains(lottery, num));
lottery[i] = num;
}
Arrays.sort(lottery);
System.out.println("彩票号码为:" + Arrays.toString(lottery));
}
private static boolean contains(int[] arr, int num) {
for (int i = 0; i < arr.length; i++) {
if (arr[i] == num) {
return true;
}
}
return false;
}
}
```
代码解析:
1. 创建一个长度为7的数组,用于存储生成的彩票号码。
2. 创建一个Random对象,用于生成随机数。
3. 使用for循环生成7个随机数,每生成一个随机数,首先判断数组中是否已经存在该数,如果存在,则继续生成随机数,直到生成一个不在数组中的随机数,将该随机数存入数组。
4. 使用Arrays.sort()方法对数组进行排序。
5. 最后将生成的彩票号码打印在控制台上。
注意事项:
1. 数组中的数字不能重复,因此在生成随机数时需要进行判断,是否已经存在于数组中。
2. Random.nextInt(int n)方法生成的随机数范围是[0, n),因此需要加上1才能生成[1, n]范围内的随机数。
3. 在判断数组中是否已经存在该数时,可以使用Arrays.asList()方法将数组转换为List,然后使用List.contains()方法进行判断,但是这种方法效率较低,因此本例中使用了一个自定义的contains()方法进行判断。
阅读全文