C语言

文曲星猜数游戏

2019-03-02  本文已影响0人  sure_风雨与晴

模拟文曲星上的猜数游戏,先由计算机随机生成一个各位相异的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;
}

上一篇下一篇

猜你喜欢

热点阅读