C语言实战开发——猜数字小游戏

题目:随机生成不相同的、1-9之间的、从小到大排序的四个整数,让玩家输入四个猜测的数字,若玩家输入的数字大小相同且数字的位置也与随机生成的相同,这样的数字记作A,大小相同但位置不同的则记为B。一共给玩家10次机会。

例:若随机生成了4 6 8 9四个数字,而用户猜测的数字为4 5 7 8,则结果就为 1A1B。


问题分析:这道题目中要求我们要随机生成四个1-9之间的不同数字,且要按从小到大的顺序排序,所以这个程序就可以分为三个板块,第一个就是生成随机数,第二个就是对生成的随机数进行排序,第三个就是在用户输入猜测数字后,对其结果进行判断。


既然是一款小游戏,欢迎界面时不可少的,所以我们就可以先把欢迎界面完成。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(){ 
    //欢迎界面 
    printf("欢迎来到猜数字游戏\n");
    printf("请按任意键继续");
    getchar();

    return 0;
}

*因为要生成随机数,所以我引入了stdlib.h和time.h两个头文件


然后我们就要定义两个数组,一个用来保存随机生成的数字,一个用来保存玩家所猜测的数字。


#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(){ 
    //欢迎界面 
    printf("欢迎来到猜数字游戏\n");
    printf("请按任意键继续");
    getchar();
   
    int a[4] = {};//储存随机生成四个数字的数组 
    int b[4] = {};//储存玩家输入的四个数字的数组
    return 0;
}

在完成了数组的定义后,我们就可去完成随机数的产生了。

//1-9的四个随机数的生成 
    
    //种种子 
    unsigned int seed = time(NULL);
    srand(seed);
    
    //随机数生成 
    for(int i = 0; i < 4; i++){
        int c = rand() % 9 + 1;
        
        if(i == 0){
            a[i] = c;
        }else{
            int j = 0;
            for(; j < i; j++){
                if(a[j] == c){
                    break;
                }
            }
            if(i == j){
                a[i] = c;
            }else{
                i--;
            }
        }
    }

*随机数的生成在记数字的demo中已经讲过,这里就不多做解释


下一步我们就要对生成出来的随机数进行排序。在这里,我选用了最通俗易懂的冒泡法来实现这个功能。

//冒泡法排序
    for(int i = 0; i < 3; i++){
        //一轮的冒泡 
        for(int i = 0; i < 3 - i; i++){
            //如果前一个数大于后一个数 
            if(a[i] > a[i + 1]){
                int c;
                int d;
                c = a[i];
                d = a[i + 1];
                a[i] = d;
                a[i + 1] = c; 
            }
        }
    }

*泡法实现方式:相邻的两个数拉出来作比较,大的往后放,像这样,最大的一个数就会被换到最后一位第一次循环选出最大的一个数字,然后从头再来一遍,选出第二大的数字,多次循环后排序完成。


在准备好随机数后我们就可以提示用户输入猜测数字了,因为我们会给用户10次的机会,所以这猜数字的整个环节都要放到一个循环中,这里我选择了while循环。因为玩家只有十次机会,所以我们还要定义一个变量来计算玩家还剩几次机会。

//用户猜数环节 
    int temp = 0;//记录次数 
    int use;//记录剩余次数 
    while(temp <= 10){
        //提示用户输入猜测的数字
        printf("请输入猜测的数字:");
    
        //接收用户输入的数字,并将其存入数组b中 
        for(int i = 0; i < 4; i++){
            int y;//用户输入的数
            scanf("%d", &y);
            b[i] = y; 
        }

将用户猜测的数字存入到数组中后,我们就可以对用户猜测的数字进行判断了。因为用户输入的每一个数字都会可能出出现位置和数值相同、位置不同但数值相同和位置和数值都不相同的三种情况。所以我们就可以将这三种情况分别来统计。我们现在就可先来统计位置和数值相同的数字个数。

        //先计算A 
        int numA = 0;
        for(int i = 0; i < 4; i++){
            if(a[i] == b[i]){
                numA = numA + 1;
            }
        }

*因为数值和位置相同即算作A,而这个A要作为游戏的结果来反馈给玩家,所以在这里我定义了一个numA来统计A的个数


统计完了A,我们就可以继续讨论位置不同但数值相同的数字个数,即B的个数。

        //再计算B
        int numB = 0;
        for(int i = 0; i < 4; i++){
            for(int j = 0; j < 4; j++){
                if(a[i] == b[j] && i != j){
                    numB = numB + 1;
                }
            }
        }

*B的讨论就要比A复杂一点,B要将每一个数字和其他的所有数字作比较,并且还要排除位置相同数值相同的数字。


在统计完A和B的数量后,我们就可以将结果反馈给玩家了,而这个结果分为两种情况,一种是成功猜对四个数字,即统计得4个A的情况。另一种则为猜数字失败,要让玩家重新猜数字,并提示玩家还剩几次机会。如果玩家猜了十次还没有猜中的话,我们就要告诉玩家游戏失败,并退出游戏。

        //把A和B的个数反馈给玩家 
        printf("%dA %dB\n", numA,numB);
        if(numA == 4){
            printf("恭喜你回答正确!");
            exit(1);
        }else{
            temp = temp + 1;
            use = 10 - temp; 
            printf("还有%d次机会", use);
        }
        if(use == 0){
            printf("错误次数过多,猜数字失败:(");
            exit(1);
        }

做到这一步,这个小游戏就完成了,以下为完整的代码。(内含小彩蛋)

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(){ 
    int a[4] = {};//储存随机生成四个数字的数组 
    int b[4] = {};//储存玩家输入的四个数字的数组 
    
    //欢迎界面 
    printf("欢迎来到猜数字游戏\n");
    printf("请按任意键继续");
    getchar();
    
    //1-9的四个随机数的生成 
    
    //种种子 
    unsigned int seed = time(NULL);
    srand(seed);
    
    //随机数生成 
    for(int i = 0; i < 4; i++){
        int c = rand() % 9 + 1;
        
        if(i == 0){
            a[i] = c;
        }else{
            int j = 0;
            for(; j < i; j++){
                if(a[j] == c){
                    break;
                }
            }
            if(i == j){
                a[i] = c;
            }else{
                i--;
            }
        }
    }
    
    //冒泡法排序
    for(int i = 0; i < 3; i++){
        //一轮的冒泡 
        for(int i = 0; i < 3 - i; i++){
            //如果前一个数大于后一个数 
            if(a[i] > a[i + 1]){
                int c;
                int d;
                c = a[i];
                d = a[i + 1];
                a[i] = d;
                a[i + 1] = c; 
            }
        }
    }  
    
    //官方外挂 :)
    /*for(int i = 0; i < 4; i++){
        printf("%d ", a[i]);
    }*/ 
    
    
    //用户猜数环节 
    int temp = 0;//记录次数 
    int use;//记录剩余次数 
    while(temp <= 10){
        //提示用户输入猜测的数字
        printf("请输入猜测的数字:");
    
        //接收用户输入的数字,并将其存入数组b中 
        for(int i = 0; i < 4; i++){
            int y;//用户输入的数
            scanf("%d", &y);
            b[i] = y; 
        } 
    
        //计算有几个A和B
        int numA = 0;
        int numB = 0;
    
        //先计算A 
        for(int i = 0; i < 4; i++){
            if(a[i] == b[i]){
                numA = numA + 1;
            }
        }
    
        //再计算B
        for(int i = 0; i < 4; i++){
            for(int j = 0; j < 4; j++){
                if(a[i] == b[j] && i != j){
                    numB = numB + 1;
                }
            }
        } 
    
        //把A和B的个数反馈给玩家 
        printf("%dA %dB\n", numA,numB);
        if(numA == 4){
            printf("恭喜你回答正确!");
            exit(1);
        }else{
            temp = temp + 1;
            use = 10 - temp; 
            printf("还有%d次机会", use);
        }
        if(use == 0){
            printf("错误次数过多,猜数字失败:(");
            exit(1);
        } 
    }
    
    
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,978评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,954评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,623评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,324评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,390评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,741评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,892评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,655评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,104评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,451评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,569评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,254评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,834评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,725评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,950评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,260评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,446评论 2 348

推荐阅读更多精彩内容