美文网首页C语言
文曲星猜数游戏

文曲星猜数游戏

作者: sure_风雨与晴 | 来源:发表于2019-03-02 11:03 被阅读0次

    模拟文曲星上的猜数游戏,先由计算机随机生成一个各位相异的4位数字,由用户来猜,根据用户猜测的结果给出提示:xAyB。其中,A前面的数字表示有几位数字不仅数字猜对了,而且位置也正确,B前面的数字表示有几位数字猜对了,但是位置不正确。
    允许用户猜的最多次数由用户从键盘输入。如果猜对,则提示“Congratulation!”;如果在规定的次数以内仍然猜不对,则给出提示“Sorry,you haven't guess the right number!”。程序结束之前,在屏幕上显示这个正确的数字。

    当问题比较复杂时,首先做的是将问题中涉及到的变量列出来,在解决问题的过程中不够再添加变量。

    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    
    void MakeDigit(int a[]);
    int InputGuess(int b[]);
    int IsRightPosition(int magic[], int guess[]);
    int IsRightDigit(int magic[], int guess[]);
    int main()
    {
        int a[10];//记录计算机所想的数字
        int b[4];//记录人猜的数
        int count;//记录已经猜的次数
        int rightDigit;//猜对的数字个数
        int rightPosition;//数字和位置都猜对的个数
        int level;//最多允许猜的次数
    
        srand(time(NULL));
        MakeDigit(a);//随机生成一个各位相异的4位数
        printf("How many times do you want to guess?");
        scanf("%d", &level);
        count = 0;
        do{
            printf("NO.%d of %d times:\n", count+1, level);
            printf("Please input a number:");
            if (InputGuess(b) != 0)//读入用户的猜测
            {
                count++;
                rightPosition = IsRightPosition(a, b);//数字和位置都猜对的个数
                rightDigit = IsRightDigit(a, b);//猜对的数字个数
                rightDigit = rightDigit - rightPosition;
                printf("%dA%dB\n", rightPosition, rightDigit);
            }
        }while (count < level && rightPosition !=4);
        if (rightPosition == 4)
            printf("Congratulations, you got it at NO.%d\n", count);
        else
            printf("Sorry, you have run out your chances, see you nest time!");
        printf("Correct answer is: %d%d%d%d\n", a[0], a[1], a[2], a[3]);
        return 0;
    }
    
    //随机生成一个4位数:将0~9这10个数字顺序放入数组a中,然后将其排列顺序随即打乱十次,取前4个数字
    void MakeDigit(int a[])
    {
        int j, k, temp;
        for (j = 0; j < 10; j++)
            a[j] = j;//顺序生成
        for (j = 0; j < 10; j++)//随机打乱十次
        {
            k = rand()%10;
            temp = a[j];
            a[j] = a[k];
            a[k] = temp;
        }
    }
    
    //读入用户猜的数,读入失败返回0
    int InputGuess(int b[])
    {
        int i, ret = 1;
        for (i = 0; i < 4; i++)
        {
            ret = scanf("%1d", &b[i]);
            if (ret != 1)//如果输入非法
            {
                printf("Input Data Type Error! \n");
                while (getchar() != '\n');//清除缓冲区中的内容
                return 0;
            }
        }
        if (b[0]==b[1] || b[0]==b[2] || b[0]==b[3] ||
            b[1]==b[2] || b[1]==b[3] || b[2]==b[3])
        {
            printf("The digits must be different from each other!\n");
            return 0;
        }
        else
            return 1;
    }
    
    //统计guess和magic数组中数字和位置都一样的个数
    int IsRightPosition(int magic[], int guess[])
    {
        int rightPosition = 0;
        int j;
        for (j = 0; j < 4; j++)
            if (guess[j] == magic[j])
                rightPosition = rightPosition + 1;
        return rightPosition;
    }
    
    //统计guess和magic数组中数字一致(不管位置)的个数
    int IsRightDigit(int magic[], int guess[])
    {
        int rightDigit = 0;
        int j, k;
        for (j = 0; j < 4; j++)
            if (guess[j] == magic[k])
                rightDigit = rightDigit + 1;
        return rightDigit;
    }
    
    

    相关文章

      网友评论

        本文标题:文曲星猜数游戏

        本文链接:https://www.haomeiwen.com/subject/kiajuqtx.html