-1

我正在做一种自我测验,您可以在其中添加问题然后自我测验。

我希望能够向您提出所有问题(如果可能,随机提出)。我已经让它有点工作,但它偶尔会错过一些问题或重复它们。

public void LoadUp() {
    if(TimeLimit) {
        timer2.Start();
    }

    KeyWords.Clear();
    Hint_Used=false;
    int QuestionCount=correct+incorrect;
    int AnswerCount=Study_Helper.Form1.QuizList.Count;
    Random random=new Random();
    int randomNumber=random.Next(0, Study_Helper.Form1.QuizList.Count);

    if(!Study_Helper.Form1.PreviousQuestions.Contains(randomNumber)) {
        Study_Helper.Form1.PreviousQuestions.Add(randomNumber);
        String raw=Study_Helper.Form1.QuizList[randomNumber].ToString();
        String[] Split=raw.Split(new char[] { '|' });
        Question=Split[0];
        richTextBox1.Text=Question;
        Answer=Split[1];
        Hint=Split[2];
        String[] NewSplit=Split[3].Split(new char[] { ',' });
        int TotalKeywords=0;

        foreach(string s in NewSplit) {
            TotalKeywords++;
        }

        for(int size=0; size<TotalKeywords-1; size++) {
            String KeyWord=NewSplit[size].ToString();
            KeyWords.Add(KeyWord);
        }
    }
    else if(QuestionCount>=AnswerCount) {
        int Total=correct-incorrect;

        if(Total<0) {
            Total=0;
        }

        timer2.Stop();
        Counter=Study_Helper.Form4.Counter;
        Form6 form6=new Form6();
        form6.Show();
        TimeLimit=false;
        MessageBox.Show("Study Questions over! you got "+Total+" in total, that's "+correct+" correct answers!", "Results", MessageBoxButtons.OK, MessageBoxIcon.Information);
        correct=0;
        incorrect=0;
        this.Close();
    }
}

它所做的是将随机数添加到保存它的列表中,并检查是否已经包含它。我觉得我遗漏了一些明显的东西来流畅地完成这项工作。

4

2 回答 2

2

我认为使用PreviousQuestions跟踪所有指数会让你自己复杂化。我建议在开始时对索引进行洗牌,所以一旦你用这个方法初始化了一个堆栈,你只需要调用randomNumbers.Pop()来获取一个新的随机数。

Stack<int> ShuffleNumbers(int count)
{
    IEnumerable<int> range = Enumerable.Range(0, count);
    Random rnd = new Random();
    return new Stack<int>(range.OrderBy(x => rnd.Next()));
}
于 2013-02-10T05:04:44.897 回答
0

最简单的方法是将列表随机化,然后按顺序开始处理。

var randomizedList = Study_Helper.Form1.QuizList.OrderBy(a => Guid.NewGuid());

foreach(var question in randomizedList)
{
    //Handle displaying the question.
}

这样做是对列表进行“排序”,但是因为我们每次都给排序器一个新的随机1 ,所以它会随机化列表。 Guid然后,我们可以将这个加扰的测验用于其余代码。

1.这不是一种“安全”的随机方式,因为有人可以对输出进行密码分析以预测问题的顺序,但您并不是在尝试加密安全,您只是在尝试打乱测验问题和这个解决方案已经足够了。有关更多信息,请参阅有关洗牌的SO question 。

于 2013-02-10T04:55:17.043 回答