利用Java编写代码,在类Network2023中,给自己班级定义一个随机点名方法randomCall()。想想办法如何不让它重复点名
时间: 2024-09-25 21:08:14 浏览: 43
在Java中,为了在`Network2023`类中实现一个随机点名方法`randomCall()`,同时避免重复点名,你可以采用一个数据结构,如ArrayList或HashSet,来存储已经点过名的学生名字。以下是简单的实现步骤:
```java
import java.util.ArrayList;
import java.util.Random;
public class Network2023 {
private ArrayList<String> students; // 学生列表
private Random random; // 随机数生成器
public Network2023() {
students = new ArrayList<>();
// 初始化学生名单...
random = new Random();
}
public void addStudent(String student) {
students.add(student);
}
public String randomCall() {
if (students.isEmpty()) {
System.out.println("班级里没人了!");
return null;
}
// 如果列表不为空
while (true) {
int index = random.nextInt(students.size()); // 生成随机索引
String selectedStudent = students.get(index); // 获取对应位置的学生
// 检查该学生是否已被点名
if (!isCalled(selectedStudent)) {
// 如果未被点名,则返回该学生
students.remove(index); // 移除已选学生防止重复
return selectedStudent;
}
}
}
private boolean isCalled(String student) {
for (String calledStudent : students) {
if (calledStudent.equals(student)) {
return true;
}
}
return false;
}
// 示例:
public static void main(String[] args) {
Network2023 network = new Network2023();
// 添加学生...
network.addStudent("小明");
network.addStudent("小红");
// 点名
System.out.println(network.randomCall());
}
}
```
在这个示例中,每次从学生列表中随机选择一个,然后检查该学生是否已经被点名。如果已被点名,就继续随机选择直到找到一个新的人。这样可以保证每次调用`randomCall()`时都不会重复点名。
阅读全文