C#代码一直工作,直到循环中添加最后一步,现在new是覆盖旧代码。

时间:2014-04-14 02:42:40

标签: c# loops

我在视觉工作室制作随机抽奖计划。它应该像这样工作:用户输入3个数字,然后点击按钮。然后程序生成3个随机数(最多)1000次,并在列表框中显示随机生成的数字。如果用户号码是按顺序生成的,那么无论用什么号码,它都会停止并说“成功!在" x"之后试图"

如果随机数与1000之后的用户数字不匹配,则会弹出一条消息说" 1000次尝试后找不到匹配项"

该程序一直有效,直到我完成最后一步。我添加了这段代码:

    //  -keep track of the matching status of each digit in a boolean

            bool theyMatch = (random1 == userEntered1stDigit) && (random2 == userEntered2ndDigit) && (random3 == userEntered3rdDigit);

            //check all three boolean match variables, if they are all true then we have a match to the winning number, exit out of the while
            if (theyMatch)
            {
                MessageBox.Show("Success! Match found for all 3 digits. It took " + myAttemptsInt + " tries.");
                break;
            }
            else
            {
                //add what happened to the event log
                MessageBox.Show("No match found after " + myAttemptsInt + " tries.");
                return;
            }

现在,当我运行它时,它会在尝试#1时停止并给出成功或失败消息。我错过了什么新代码覆盖旧代码?

以下是整个事情:

     public Form1()
    {
        InitializeComponent();
    }

    //DECLARE CLASS LEVEL FIELD VARIABLES
    int CONST_cashPayoutPick3 = 500;
    int CONST_cashPayoutPick4 = 5000;
    int CONST_cashPayoutPick5 = 50000;

    private void myBtnGenRandomNumbers_Click(object sender, EventArgs e)
    {
        //DECLARE LOCAL VARIABLES
        int userEntered1stDigit = 0;
        int userEntered2ndDigit = 0;
        int userEntered3rdDigit = 0;


        //INPUT-VALIDATION
        //winning number: validate the 1st digit to be numeric, if not display error message and return
        if (int.TryParse(myTxtBox1stDigit.Text, out userEntered1stDigit))
        {
            //ok
        }
        else
        {
            MessageBox.Show("Please enter a number in the first box");
            return;
        }
        //winning number: validate the 2nd digit to be numeric, if not display error message and return
        if (int.TryParse(myTxtBox2ndDigit.Text, out userEntered2ndDigit))
        {
            //ok
        }
        else
        {
            MessageBox.Show("Please enter a number in the second box");
            return;
        }
        //winning number: validate the 3rd digit to be numeric, if not display error message and return
        if (int.TryParse(myTxtBox3rdDigit.Text, out userEntered3rdDigit))
        {
            //ok
        }
        else
        {
            MessageBox.Show("Please enter a number in the third box");
            return;
        }


        //INITIALIZE ANY VARIABLES
        userEntered1stDigit = int.Parse(myTxtBox1stDigit.Text);
        userEntered2ndDigit = int.Parse(myTxtBox2ndDigit.Text);
        userEntered3rdDigit = int.Parse(myTxtBox3rdDigit.Text);

        //GOOD SO FAR

        //PROCESSING
        //setup your own Random number generator object
        int random1 = 0;
        int random2 = 0;
        int random3 = 0;

        Random myRandomNumberObject = new Random();
        int matchNum1;
        int matchNum2;
        int matchNum3;

        //clear the list box
        myListBoxResults.Items.Clear();

        //set number of attempts = 0
        int myAttemptsInt;
        myAttemptsInt = 0;


        //LOOP THROUGH AND CREATE SETS OF 3 RANDOM DIGITS EACH TIME THROUGH LOOP UNTIL A MATCH IS FOUND OR TRY 1,000 TIMES
        while (myAttemptsInt <= 1000) 
        {

            if (myAttemptsInt <= 999)
            {
                //ok
            }
            else
            {
                break;
            }

            //get next random digit generated from 0 to 9, for your generated digit position 1
            random1 = myRandomNumberObject.Next(10);
            //get next random digit generated from 0 to 9, for your generated digit position 2
            random2 = myRandomNumberObject.Next(10);
            //get next random digit generated from 0 to 9, for your generated digit position 3
            random3 = myRandomNumberObject.Next(10);


            //display the number of match attempts so far

            //attempt # originally went here
            myAttemptsInt = myAttemptsInt + 1;

            int index = myListBoxResults.Items.Add("Attempt # " + myAttemptsInt);

            //display the generated digit 1,2,3 in the labels on the Form
            matchNum1 = random1;
            myLabelGenerated1stDigit.Text = matchNum1.ToString();
            matchNum2 = random2;
            myLabelGenerated2ndDigit.Text = matchNum2.ToString();
            matchNum3 = random3;
            myLabelGenerated3rdDigit.Text = matchNum3.ToString();

            //set the Label BackColor of all the generated digits to Color.LightGray
            myLabelGenerated1stDigit.BackColor= Color.LightGray;
            myLabelGenerated2ndDigit.BackColor = Color.LightGray;
            myLabelGenerated3rdDigit.BackColor = Color.LightGray;

            //for any generated digit that matches the winning digit,
            if (random1 == userEntered1stDigit)
            {
                myLabelGenerated1stDigit.BackColor = Color.LightGreen;
            }
            if (random2 == userEntered2ndDigit)
            {
                myLabelGenerated2ndDigit.BackColor = Color.LightGreen;
            }
            if (random3 == userEntered3rdDigit)
            {
                myLabelGenerated3rdDigit.BackColor = Color.LightGreen;
            }

            //  -keep track of the matching status of each digit in a boolean

            bool theyMatch = (random1 == userEntered1stDigit) && (random2 == userEntered2ndDigit) && (random3 == userEntered3rdDigit);

            //check all three boolean match variables, if they are all true then we have a match to the winning number, exit out of the while
            if (theyMatch)
            {
                MessageBox.Show("Success! Match found for all 3 digits. It took " + myAttemptsInt + " tries.");
                break;
            }
            else
            {
                //add what happened to the event log
                MessageBox.Show("No match found after " + myAttemptsInt + " tries.");
                return;
            }

        } 

1 个答案:

答案 0 :(得分:3)

如果没有检查循环是否已被消耗,则返回 删除其他并将其放在外面,同时也更改中断返回

//...

    if (theyMatch)
    {
        MessageBox.Show("Success! Match found for all 3 digits. It took " + myAttemptsInt + " tries.");
        return;
    }

}

MessageBox.Show("No match found after " + myAttemptsInt + " tries.");