takeru020925 2021-07-02 15:45 采纳率: 0%
浏览 32

C语言编写猜数字小游戏

该游戏可以由程序随机产生一个N位数字,或由用户输入一个N位数字,作为待猜测数字(各位数字不重复出现)。玩游戏者开始猜测后,可以有M次机会输入数字来匹配上面的待猜测数字。用户每输入一次,系统给出本次猜测结果:A表示位置正确且数字正确,B表示数字正确而位置不正确。比如:2A1B,表示2位位置正确且数字正确,1位数字正确但是位置不正确。
某次猜中后,游戏结束。若M次机会用完,游戏也结束。

  • 写回答

1条回答 默认 最新

  • 张小兔爱钱钱 2023-06-10 10:15
    关注
    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    
    // 生成 n 位不重复的随机数
    void generateRandomNumber(int* nums, int n) {
        int i, j, t;
        srand(time(NULL));
        for (i = 0; i < n; i++) {
            // 保证不重复
            do {
                t = rand() % 10;
                for (j = 0; j < i; j++) {
                    if (nums[j] == t) {
                        break;
                    }
                }
            } while (j < i);
            nums[i] = t;
        }
    }
    
    // 判断两个数是否匹配,并返回 A 和 B 的数量
    void judge(int* ans, int* guess, int n, int* a, int* b) {
        int i, j;
        *a = *b = 0;
        for (i = 0; i < n; i++) {
            if (ans[i] == guess[i]) {
                (*a)++;
            } else {
                for (j = 0; j < n; j++) {
                    if (ans[i] == guess[j]) {
                        (*b)++;
                        break;
                    }
                }
            }
        }
    }
    
    int main() {
        const int MAX_CHANCES = 10; // 最多猜测次数
        int nums[10], ans[10], guess[10];
        int n, m, i, j, a, b;
        char input[20];
    
        // 输入随机数位数
        printf("请输入随机数的位数:");
        fgets(input, sizeof(input), stdin);
        n = atoi(input);
    
        // 随机生成待猜测数字
        generateRandomNumber(ans, n);
        printf("已经生成了一个%d位的随机数,请开始猜测。", n);
    
        // 开始猜测
        for (m = 1; m <= MAX_CHANCES; m++) {
            printf("\n第%d次猜测:", m);
            fgets(input, sizeof(input), stdin);
            for (i = 0; i < n; i++) {
                guess[i] = input[i] - '0';
            }
            judge(ans, guess, n, &a, &b);
            if (a == n) { // 猜中了
                printf("恭喜你,猜对了!\n");
                break;
            } else {
                printf("%dA%dB。\n", a, b);
            }
        }
    
        if (m > MAX_CHANCES) { // 次数用完了
            printf("很遗憾,没有猜中。正确答案是:");
            for (i = 0; i < n; i++) {
                printf("%d", ans[i]);
            }
        }
    
        return 0;
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3