
本文将指导您如何解决测验应用中重复出现问题的问题。通过使用 Java 集合框架,特别是 List 和 Collections.shuffle() 方法,我们将演示如何从问题列表中随机选择指定数量的不重复问题。
在开发测验应用程序时,一个常见的问题是如何避免问题重复出现。以下提供一种使用 Java 解决此问题的有效方法,其核心思想是先创建一个包含所有问题索引的列表,然后对该列表进行洗牌,最后从中选取指定数量的索引,从而保证选取的问题不重复。
实现步骤:
创建包含所有问题索引的列表:
立即学习“Java免费学习笔记(深入)”;
首先,获取问题列表的大小,并创建一个包含从 0 到 quizQuestions.size() - 1 的整数的 List。这些整数代表问题在原始列表中的索引。
int numQuestions = quizQuestions.size();
List<Integer> randomQuestionIndexes = IntStream.range(0, numQuestions)
.boxed()
.collect(Collectors.toList());这里使用了 IntStream.range() 创建一个整数流,boxed() 将其转换为 Integer 对象流,最后使用 Collectors.toList() 将其收集到一个 List<Integer> 中。
对索引列表进行洗牌:
使用 Collections.shuffle() 方法对索引列表进行洗牌,从而随机排列索引的顺序。
Collections.shuffle(randomQuestionIndexes);
Collections.shuffle() 方法会原地修改 randomQuestionIndexes 列表,使其元素的顺序随机化。
选取指定数量的索引:
现在,randomQuestionIndexes 列表包含了随机排列的问题索引。可以从该列表中选取前 n 个索引,其中 n 是所需问题的数量。
int numberOfQuestionsToSelect = 3; // 例如,选取 3 个问题 List<Integer> selectedIndexes = randomQuestionIndexes.subList(0, numberOfQuestionsToSelect);
subList() 方法返回一个视图,该视图是原始列表的一部分。需要注意的是,对子列表的修改会反映到原始列表上,反之亦然。
使用选取的索引获取问题:
最后,使用选取的索引从 quizQuestions 列表中获取对应的问题。
List<QuizQuestion> selectedQuestions = new ArrayList<>();
for (Integer index : selectedIndexes) {
selectedQuestions.add(quizQuestions.get(index));
}这将创建一个新的 List,其中包含随机选择且不重复的问题。
完整示例代码:
import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.IntStream;
public class QuizQuestionSelector {
public static List<QuizQuestion> selectRandomQuestions(List<QuizQuestion> quizQuestions, int numberOfQuestionsToSelect) {
int numQuestions = quizQuestions.size();
if (numberOfQuestionsToSelect > numQuestions) {
throw new IllegalArgumentException("Requested number of questions exceeds the available number of questions.");
}
List<Integer> randomQuestionIndexes = IntStream.range(0, numQuestions)
.boxed()
.collect(Collectors.toList());
Collections.shuffle(randomQuestionIndexes);
List<Integer> selectedIndexes = randomQuestionIndexes.subList(0, numberOfQuestionsToSelect);
List<QuizQuestion> selectedQuestions = new ArrayList<>();
for (Integer index : selectedIndexes) {
selectedQuestions.add(quizQuestions.get(index));
}
return selectedQuestions;
}
public static void main(String[] args) {
// 示例用法
List<QuizQuestion> quizQuestions = new ArrayList<>();
quizQuestions.add(new QuizQuestion("Question 1"));
quizQuestions.add(new QuizQuestion("Question 2"));
quizQuestions.add(new QuizQuestion("Question 3"));
quizQuestions.add(new QuizQuestion("Question 4"));
quizQuestions.add(new QuizQuestion("Question 5"));
List<QuizQuestion> selectedQuestions = selectRandomQuestions(quizQuestions, 3);
System.out.println("Selected Questions:");
for (QuizQuestion question : selectedQuestions) {
System.out.println(question.getText());
}
}
// 辅助类:QuizQuestion
static class QuizQuestion {
private String text;
public QuizQuestion(String text) {
this.text = text;
}
public String getText() {
return text;
}
}
}注意事项:
总结:
通过使用 List 和 Collections.shuffle() 方法,可以有效地从问题列表中随机选择指定数量的不重复问题。这种方法简单易懂,并且性能良好,适用于大多数测验应用场景。 这种方法不仅可以用于选择问题,还可以用于其他需要随机选择不重复元素的场景。希望本文能够帮助您解决测验应用中的重复问题问题,并提升您的开发效率。
以上就是创建不重复问题的测验应用:Java 解决方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号