
本文旨在帮助开发者解决在Java测验应用中出现重复问题的问题。通过使用Collections.shuffle方法对问题索引列表进行洗牌,并从中依次移除索引,可以有效地避免重复问题的出现,确保测验的随机性和公平性。本文将提供详细的代码示例和步骤,帮助读者理解和实现这一解决方案。
在开发测验应用时,确保问题不重复出现至关重要。一种有效的解决方案是使用洗牌算法,对问题索引进行随机排序,然后按顺序选取问题。这种方法避免了使用 Random 类生成随机数时可能出现的重复问题。
步骤 1:创建问题索引列表
首先,创建一个包含所有问题索引的列表。假设 quizQuestions 是一个包含所有测验问题的列表,我们可以使用 IntStream 生成一个从 0 到 quizQuestions.size() - 1 的整数流,并将其转换为 List<Integer>。
立即学习“Java免费学习笔记(深入)”;
import java.util.List;
import java.util.stream.IntStream;
import java.util.stream.Collectors;
import java.util.Collections;
// 假设 quizQuestions 是一个 List<QuizQuestion>
int numQuestions = quizQuestions.size();
List<Integer> randomQuestionIndexes = IntStream.range(0, numQuestions)
.boxed()
.collect(Collectors.toList());步骤 2:洗牌索引列表
使用 Collections.shuffle() 方法对索引列表进行洗牌,使其顺序随机化。
Collections.shuffle(randomQuestionIndexes);
步骤 3:按顺序选取问题
现在,randomQuestionIndexes 列表中包含了随机排列的问题索引。你可以按顺序从列表中选取指定数量的问题,而无需担心重复问题。
int numberOfQuestionsToSelect = 3; // 例如,选择 3 个问题
List<QuizQuestion> selectedQuestions = new ArrayList<>();
for (int i = 0; i < numberOfQuestionsToSelect; i++) {
int index = randomQuestionIndexes.get(i);
QuizQuestion question = quizQuestions.get(index);
selectedQuestions.add(question);
}完整示例代码:
import java.util.ArrayList;
import java.util.List;
import java.util.stream.IntStream;
import java.util.stream.Collectors;
import java.util.Collections;
public class QuizGenerator {
private List<QuizQuestion> quizQuestions;
public QuizGenerator(List<QuizQuestion> quizQuestions) {
this.quizQuestions = quizQuestions;
}
public List<QuizQuestion> generateRandomQuiz(int numberOfQuestionsToSelect) {
int numQuestions = quizQuestions.size();
List<Integer> randomQuestionIndexes = IntStream.range(0, numQuestions)
.boxed()
.collect(Collectors.toList());
Collections.shuffle(randomQuestionIndexes);
List<QuizQuestion> selectedQuestions = new ArrayList<>();
for (int i = 0; i < numberOfQuestionsToSelect && i < numQuestions; i++) { // 确保 i 不超过 numQuestions
int index = randomQuestionIndexes.get(i);
QuizQuestion question = quizQuestions.get(index);
selectedQuestions.add(question);
}
return selectedQuestions;
}
public static void main(String[] args) {
// 创建一些示例问题
List<QuizQuestion> questions = new ArrayList<>();
questions.add(new QuizQuestion("问题 1"));
questions.add(new QuizQuestion("问题 2"));
questions.add(new QuizQuestion("问题 3"));
questions.add(new QuizQuestion("问题 4"));
questions.add(new QuizQuestion("问题 5"));
// 创建 QuizGenerator 实例
QuizGenerator generator = new QuizGenerator(questions);
// 生成包含 3 个随机问题的测验
List<QuizQuestion> quiz = generator.generateRandomQuiz(3);
// 打印测验问题
for (QuizQuestion question : quiz) {
System.out.println(question.getQuestionText());
}
}
}
class QuizQuestion {
private String questionText;
public QuizQuestion(String questionText) {
this.questionText = questionText;
}
public String getQuestionText() {
return questionText;
}
}注意事项:
总结:
通过使用 Collections.shuffle() 方法对问题索引列表进行洗牌,可以有效地避免在Java测验应用中出现重复问题。这种方法简单易懂,并且能够保证测验的随机性和公平性。 记住处理边界条件,并根据实际情况选择合适的随机选择算法。
以上就是创建不重复问题的Java测验应用教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号