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