C语言实现数独小游戏

本文实例为大家分享了C语言实现数独小游戏的具体代码,供大家参考,具体内容如下

输入包含9x9的已知数字,空位用0补齐,中间用空格隔开。(输入数独题目确保正确)
输出为输入数独题目的解。

玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行、每一列、每一个同色九宫内的数字均含1-9,不重复。

样例输入:

样例输出:

代码:

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

int *fillnumber(int a[9][9][10],int number,int i,int j){
    for (int k=0;k<9;k++){
        a[i][k][number]++;
        a[k][j][number]++;
    }
    for (int n=0;n<3;n++){
        for (int m=0;m<3;m++){
            a[i/3*3+n][j/3*3+m][number]++;
        }
    }
    return a;
}
int *resetnumber(int a[9][9][10],int number,int i,int j){
    for (int k=0;k<9;k++){
        a[i][k][number]--;
        a[k][j][number]--;
    }
    for (int n=0;n<3;n++){
        for (int m=0;m<3;m++){
            a[i/3*3+n][j/3*3+m][number]--;
        }
    }
    return a;
}

void search(int step, int a[9][9],int g[9][9][10]){
    if (step==0) {
        for (int i=0;i<9;i++){
            for (int j=0;j<9;j++){
                printf("%d ",a[i][j]);
            }
            printf("\n");
        }
        exit(0);
    }

    for (int i=0;i<9;i++){
        for (int j=0;j<9;j++){
            if (a[i][j]==0) {
                for (int number=1;number<10;number++){
                    if (g[i][j][number]==0){
                        fillnumber(g,number,i,j);
                        a[i][j]=number;
                        search(step-1,a,g);
                        a[i][j]=0;
                        resetnumber(g,number,i,j);
                    }
                }
                return;
            }
        }
    }
}

int main(int argc, const char * argv[]) {
    int a[9][9];
    int abool[9][9][10];
    int step=0;
    for (int i =0;i<9;i++){
        for (int j=0;j<9;j++){
            for (int k=1;k<10;k++) {
                abool[i][j][k]=0;
            }
        }
    }
    for (int i =0;i<9;i++){
        for (int j=0;j<9;j++){
            scanf("%d",&a[i][j]);
            if (a[i][j]==0) {
                step++;
            }
            else{
                fillnumber(abool,a[i][j],i,j);

            }
        }
    }
    search(step,a,abool);
    return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C语言数独游戏的求解方法

    数独游戏的解法: 先将数独分为九个格子,用一个数组将每个小九宫格的候选数存放下来,将候选数挨个放进数独里的空位,如果这一行和这一列都没有这个数字,继续放入下一个,如果不能放入的话就回到上一步继续尝试,直到成功求出数独的解为止: 比如这个数独第一个九宫格的候选数就有1,2,7,8,9,我们需要从1开始放入第一个格子挨个尝试直到8的时候发现剩下的两个格子都不能放入 这个时候我们就要撤回上一个插入的7,发现8仍然不能放入,就继续撤回2,发现8可以放入,就将8放入3号位置,然后将9插入 这个时候我们发现

  • C语言实现数独游戏

    本文实例为大家分享了C语言实现数独游戏的具体代码,供大家参考,具体内容如下 目标 写一个数独游戏,有以下功能: 1:能随机产生题目并给出答案. 2:求解输入的题目并输出答案. 实现说明 参照百度百科等资料可以知道求解数独的主要算法是:1.通过行.列和宫格确定可填数字.2.所有可行数字逐一填入得到结果.本程序求解数独部分也采用这样的算法.而生成题目的算法是: 随机产生一个长度为9的一维数组,元素是随机产生的1到9的不同数字.比如为root = [1, 4, 3, 5, 6 ,7, 8 ,9, 2]

  • C语言实现数独游戏的求解

    玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行.每一列.每一个同色九宫内的数字均含1-9,不重复. 输入包含9x9的已知数字,空位用0补齐,中间用空格隔开.(输入数独题目确保正确) 输出为输入数独题目的解. 样例输入: 8 0 0 0 0 0 0 0 0 0 0 3 6 0 0 0 0 0 0 7 0 0 9 0 2 0 0 0 5 0 0 0 7 0 0 0 0 0 0 0 4 5 7 0 0 0 0 0 1 0 0 0 3 0 0 0 1 0 0 0 0 6 8

  • C语言实现数独小游戏

    本文实例为大家分享了C语言实现数独小游戏的具体代码,供大家参考,具体内容如下 输入包含9x9的已知数字,空位用0补齐,中间用空格隔开.(输入数独题目确保正确)输出为输入数独题目的解. 玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一行.每一列.每一个同色九宫内的数字均含1-9,不重复. 样例输入: 样例输出: 代码: #include <stdio.h> #include <stdlib.h> int *fillnumber(int a[9][9][10],

  • C语言实现五子棋小游戏

    首先我们先来看一个稍微简单些的实现方式: #include <stdio.h> #include <stdlib.h> #define N 15 int chessboard[N + 1][N + 1] = { 0 }; int whoseTurn = 0; void initGame(void); void printChessboard(void); void playChess(void); int judge(int, int); int main(void) { init

  • C语言实现2048小游戏

    本文实例为大家分享了C语言实现2048小游戏的具体代码,供大家参考,具体内容如下 具有以下特点: 1.linux下完成 2.非堵塞键盘读取 3.随机生成2和4 #include <stdio.h> #include <stdlib.h> #include <unistd.h> #define TTY_PATH "/dev/tty" #define STTY_ON "stty raw -echo -F" #define STTY_O

  • C语言实现俄罗斯方块小游戏

    C语言实现俄罗斯方块小游戏的制作代码,具体内容如下 #include <stdio.h> #include <stdlib.h> #include <unistd.h> #define TTY_PATH "/dev/tty" #define STTY_ON "stty raw -echo -F" #define STTY_OFF "stty -raw echo -F" int map[21][14]; char

  • 利用C语言编写“剪刀石头布”小游戏

    前言 大家好~ 我是一名C语言初学者,学了C语言基础后,我制作了一个小游戏:剪刀石头布. 希望大家能对我的思路和代码提出小Tips(eg.更简便的方法与程序) 我也会虚心接受大家的建议~ 一.游戏原理 "剪刀石头布"这个游戏,想必大家都很熟悉了. 两个人在玩游戏时,事先都不知道对方将要出什么,这中间存在着一种随机性. 而这种随机性相当于C语言里stdlib.h库中rand()函数,rand()函数用来产生随机数,因为rand是根据提供给srand()的种子值返回一个随机数,所以要使每次

  • C语言三子棋小游戏的实现代码

    本文实例为大家分享了C语言三子棋小游戏的具体代码,供大家参考,具体内容如下 一.介绍: 运用C语言的数组等相关知识:实现一个简易的三子棋小游戏: 三子棋小游戏的大概内容为 此游戏在设计时:总共设计了三个文件: game.h: 类型的声明和函数的声明 game.c:函数功能的具体实现 test.c: 测试文件 二.具体实现: (1).game.h模块: 代码实现如下: #define _CRT_SECURE_NO_WARNINGS 1 //头文件包含 #include <stdio.h> #in

  • C语言实现飞机小游戏

    本文实例为大家分享了C语言实现飞机小游戏的具体代码,供大家参考,具体内容如下 #include<stdio.h> #include<windows.h> int zdj_x,zdj_y; int zd_x,zd_y; int dj_x,dj_y; int speed; int map[21][41]; int score; int H=20,C=40; //墙是1:飞机2:子弹3:敌机4: void start()//设置初始值 { zdj_x=15; zdj_y=20; zd_x

  • 利用C语言实现扫雷小游戏

    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 说明:该游戏的实现需要建立三个文件 test2.c:整个游戏,开始游戏/退出游戏的大体执行流程 game2.c:具体实现扫雷游戏功能的函数定义 game.h:宏定义,函数声明,引用相关C库函数的头文件 test2.c 游戏的大体执行流程 #include"game2.h" //菜单函数 void menu() { printf("**************************\n")

  • C语言实现扫雷小游戏详解

    本文实例为大家分享了C语言实现扫雷小游戏的具体代码,供大家参考,具体内容如下 一.实现功能 首先显示一个小菜单,选择是否玩游戏.当用户选择退出时,程序运行结束,当用户选择玩游戏时,将提示用户输入扫雷位置坐标.当用户输入坐标超出棋盘范围或者位置之前已经进行扫雷时,将提示用户重新输入.当用户输入正确坐标时,如果输入位置没雷将会显示当前位置周边有几个雷,直到将所有雷找出后,重新显示菜单.当输入位置有雷时,游戏结束,重新显示菜单. 二.分析与介绍 首先编写程序开始前,我们要清楚知道棋盘时二维的,所以这里

  • Java实现数独小游戏

    本文实例为大家分享了Java实现数独小游戏的具体代码,供大家参考,具体内容如下 题目要求: 制作一个数独游戏.数据游戏拼图由一个3*3的九宫格组成,每个格式又分成一个小九宫格,共九九八十一个小格子.游戏规则:游戏开始前会有一些格式了写好了1-9的数,在剩下的格式里填写1-9的数,直到把所有格式填满,要求任何一行或一列或者任一个小九宫中没有相同的数字.拼图示例如下: 任务要求: (1) 可以根据在九宫格中初始给出的数字个数设定游戏难度,如初始给出30个数设定为难.35个数设定为中等难度.40个数设

随机推荐