
本文将指导您如何解决测验应用中重复出现问题的问题。通过使用 Java 集合框架,特别是 List 和 Collections.shuffle() 方法,我们将演示如何从问题列表中随机选择指定数量的不重复问题。
在开发测验应用程序时,一个常见的问题是如何避免问题重复出现。以下提供一种使用 Java 解决此问题的有效方法,其核心思想是先创建一个包含所有问题索引的列表,然后对该列表进行洗牌,最后从中选取指定数量的索引,从而保证选取的问题不重复。
实现步骤:
-
创建包含所有问题索引的列表:
立即学习“Java免费学习笔记(深入)”;
首先,获取问题列表的大小,并创建一个包含从 0 到 quizQuestions.size() - 1 的整数的 List。这些整数代表问题在原始列表中的索引。
int numQuestions = quizQuestions.size(); List
randomQuestionIndexes = IntStream.range(0, numQuestions) .boxed() .collect(Collectors.toList()); 这里使用了 IntStream.range() 创建一个整数流,boxed() 将其转换为 Integer 对象流,最后使用 Collectors.toList() 将其收集到一个 List
中。 -
对索引列表进行洗牌:
使用 Collections.shuffle() 方法对索引列表进行洗牌,从而随机排列索引的顺序。
Collections.shuffle(randomQuestionIndexes);
Collections.shuffle() 方法会原地修改 randomQuestionIndexes 列表,使其元素的顺序随机化。
-
选取指定数量的索引:
现在,randomQuestionIndexes 列表包含了随机排列的问题索引。可以从该列表中选取前 n 个索引,其中 n 是所需问题的数量。
int numberOfQuestionsToSelect = 3; // 例如,选取 3 个问题 List
selectedIndexes = randomQuestionIndexes.subList(0, numberOfQuestionsToSelect); subList() 方法返回一个视图,该视图是原始列表的一部分。需要注意的是,对子列表的修改会反映到原始列表上,反之亦然。
-
使用选取的索引获取问题:
最后,使用选取的索引从 quizQuestions 列表中获取对应的问题。
List
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 selectRandomQuestions(List quizQuestions, int numberOfQuestionsToSelect) {
int numQuestions = quizQuestions.size();
if (numberOfQuestionsToSelect > numQuestions) {
throw new IllegalArgumentException("Requested number of questions exceeds the available number of questions.");
}
List randomQuestionIndexes = IntStream.range(0, numQuestions)
.boxed()
.collect(Collectors.toList());
Collections.shuffle(randomQuestionIndexes);
List selectedIndexes = randomQuestionIndexes.subList(0, numberOfQuestionsToSelect);
List selectedQuestions = new ArrayList<>();
for (Integer index : selectedIndexes) {
selectedQuestions.add(quizQuestions.get(index));
}
return selectedQuestions;
}
public static void main(String[] args) {
// 示例用法
List 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 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;
}
}
} 注意事项:
- 确保 numberOfQuestionsToSelect 的值小于或等于 quizQuestions.size(),否则会抛出 IllegalArgumentException 异常。
- QuizQuestion 类是一个示例类,需要根据实际情况进行替换。
- 此方法修改了原始列表的顺序,如果需要保留原始列表的顺序,请先创建一个副本。
总结:
通过使用 List 和 Collections.shuffle() 方法,可以有效地从问题列表中随机选择指定数量的不重复问题。这种方法简单易懂,并且性能良好,适用于大多数测验应用场景。 这种方法不仅可以用于选择问题,还可以用于其他需要随机选择不重复元素的场景。希望本文能够帮助您解决测验应用中的重复问题问题,并提升您的开发效率。










