POJ2676题解(dfs,附:视频讲解)

2024-02-05 08:38
文章标签 视频 讲解 dfs 题解 poj2676

本文主要是介绍POJ2676题解(dfs,附:视频讲解),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意:

Time Limit:Memory Limit:
2000MS65536K
  • Description:
    数独是一项非常简单的任务。一个有9行9列的正方形表格被分成9个较小的正方形3x3,如图所示。在某些单元格中,是从1到9的十进制数字。其他单元格是空的。目标是用1到9的十进制数字填充空单元格,每个单元格一个数字,这样在每行、每列和每个标记的3x3子方格中,1到9的所有数字都会出现。写一个程序来解决给定的数独任务。
    在这里插入图片描述
  • Input:
    输入数据将从测试用例的数量开始。 对于每个测试用例,紧跟着表的行的是9行。 在每一行上,给出了一个准确的9位十进制数字的字符串,对应于该行中的单元格。 如果单元格为空,则用0表示。
  • Output:
    对于每个测试用例,您的程序应以与输入数据相同的格式打印解决方案。 空单元格必须根据规则进行填充。 如果解决方案不是唯一的,则程序可以打印其中任何一种。
  • Sample Input:
1
103000509
002109400
000704000
300502006
060000050
700803004
000401000
009205800
804000107
  • Sample Output:
143628579
572139468
986754231
391542786
468917352
725863914
237481695
619275843
854396127

视频讲解:

POJ2676

解题代码:

#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstring>
using namespace std;
int map[9][9] = { 0 };
int flag = 0;
void dfs(int i, int j)
{   if (flag)return;if (j > 8){i++;j = 0;if (i > 8){flag = 1;for (int m = 0; m < 9; m++){for (int n = 0; n < 9; n++){cout << map[m][n];}cout << endl;}return;}}if (map[i][j] == 0){   int f[10] = { 0,0 };for (int k = 0; k < 9; k++)f[map[i][k]]++;for (int k = 0; k < 9; k++)f[map[k][j]]++;for (int k = i / 3 * 3; k < i / 3 * 3 + 3; k++)for (int l = j / 3 * 3; l < j / 3 * 3 + 3; l++)f[map[k][l]]++;for (int k = 1; k < 10; k++)if (f[k] == 0){   map[i][j] = k;dfs(i, j + 1);map[i][j] = 0;}}else {dfs(i, j + 1);}return;
}
int main()
{int c;cin >> c;char ch;for (int i = 0; i < c; i++){   flag = 0;for (int m = 0; m < 9; m++)for (int n = 0; n < 9; n++){   cin >> ch;map[m][n]=ch-'0';}dfs(0, 0);}
}

这篇关于POJ2676题解(dfs,附:视频讲解)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/680347

相关文章

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

MySQL连表查询之笛卡尔积查询的详细过程讲解

《MySQL连表查询之笛卡尔积查询的详细过程讲解》在使用MySQL或任何关系型数据库进行多表查询时,如果连接条件设置不当,就可能发生所谓的笛卡尔积现象,:本文主要介绍MySQL连表查询之笛卡尔积查... 目录一、笛卡尔积的数学本质二、mysql中的实现机制1. 显式语法2. 隐式语法3. 执行原理(以Nes

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

Java进程CPU使用率过高排查步骤详细讲解

《Java进程CPU使用率过高排查步骤详细讲解》:本文主要介绍Java进程CPU使用率过高排查的相关资料,针对Java进程CPU使用率高的问题,我们可以遵循以下步骤进行排查和优化,文中通过代码介绍... 目录前言一、初步定位问题1.1 确认进程状态1.2 确定Java进程ID1.3 快速生成线程堆栈二、分析

javascript fetch 用法讲解

《javascriptfetch用法讲解》fetch是一个现代化的JavaScriptAPI,用于发送网络请求并获取资源,它是浏览器提供的全局方法,可以替代传统的XMLHttpRequest,这篇... 目录1. 基本语法1.1 语法1.2 示例:简单 GET 请求2. Response 对象3. 配置请求

Java Stream.reduce()方法操作实际案例讲解

《JavaStream.reduce()方法操作实际案例讲解》reduce是JavaStreamAPI中的一个核心操作,用于将流中的元素组合起来产生单个结果,:本文主要介绍JavaStream.... 目录一、reduce的基本概念1. 什么是reduce操作2. reduce方法的三种形式二、reduce

CSS引入方式和选择符的讲解和运用小结

《CSS引入方式和选择符的讲解和运用小结》CSS即层叠样式表,是一种用于描述网页文档(如HTML或XML)外观和格式的样式表语言,它主要用于将网页内容的呈现(外观)和结构(内容)分离,从而实现... 目录一、前言二、css 是什么三、CSS 引入方式1、行内样式2、内部样式表3、链入外部样式表四、CSS 选