和蓝桥杯以前一个题一样,但是数据加强了,博主水平有限,没做出来,先在这里记录一下,这里正解,下面是博主的超时做法。最近准备考研,不能深入学习了。

题目描述

数独是一种传统益智游戏,你需要把一个9 × 9的数独补充完整,使得图中每行、每列、每个3 × 3的九宫格内数字1~9均恰好出现一次。

请编写一个程序填写数独。

输入格式
输入包含多组测试用例。

每个测试用例占一行,包含81个字符,代表数独的81个格内数据(顺序总体由上到下,同行由左到右)。

每个字符都是一个数字(1-9)或一个”.”(表示尚未填充)。

您可以假设输入中的每个谜题都只有一个解决方案。

文件结尾处为包含单词“end”的单行,表示输入结束。

输出格式
每个测试用例,输出一行数据,代表填充完全后的数独。

样例

  1. 输入样例:
  2. .2738..1..1...6735.......293.5692.8...........6.1745.364.......9518...7..8..6534.
  3. ......52..8.4......3...9...5.1...6..2..7........3.....6...1..........7.4.......3.
  4. end
  5. 输出样例:
  6. 527389416819426735436751829375692184194538267268174593643217958951843672782965341
  7. 416837529982465371735129468571298643293746185864351297647913852359682714128574936
  1. #include<iostream>
  2. #include<algorithm>
  3. #include<string>
  4. using namespace std;
  5. int m[10][10],kx[10][10],ky[10][10],kk[10][10]; //kx:行 ky:列 kk:方格
  6. int ans;
  7.  
  8. void dfs(int x, int y) {
  9. if (ans)return;
  10. if (x == 9) {
  11. ans = 1;
  12. for (int i = 0; i < 9; i++) {
  13. for (int j = 0; j < 9; j++)
  14. cout << m[i][j];
  15. }
  16. cout << "\n";
  17. }
  18. if (m[x][y] == 0) {
  19. for (int i = 1; i < 10; i++) {
  20. if (kx[x][i]==0&&ky[y][i]==0&& kk[3 * (x / 3) + (y / 3)][i]==0) {
  21.  
  22. kx[x][i] = 1;
  23. ky[y][i] = 1;
  24. kk[3 * (x/3) + (y/3)][i] = 1;
  25. m[x][y] = i;
  26.  
  27. if (y == 8)dfs(x + 1,0);
  28. else dfs(x, y + 1);
  29.  
  30. kx[x][i] = 0;
  31. ky[y][i] = 0;
  32. kk[3 * (x / 3) + (y / 3)][i] = 0;
  33. m[x][y] = 0;
  34. }
  35. }
  36. return;
  37. }
  38. else {
  39. if (y == 8)dfs(x + 1, 1);
  40. else dfs(x, y + 1);
  41. }
  42. }
  43.  
  44. int main() {
  45. ios::sync_with_stdio(0);
  46. cin.tie(0),cout.tie(0);
  47. string a;
  48. while (cin >> a&&a[0] != 'e') {
  49. memset(m, 0, sizeof(m));
  50. memset(kx, 0, sizeof(kx));
  51. memset(ky, 0, sizeof(ky));
  52. memset(kk, 0, sizeof(kk));
  53. ans = 0;
  54. int len = a.size();
  55. for (int i = 0; i < len; i++)
  56. {
  57. if (a[i] != '.') {
  58. m[i / 9][i % 9] = a[i] - '0'; //终于把地图做好了。。
  59. kx[i / 9][a[i] - '0'] = 1;
  60. ky[i % 9][a[i] - '0'] = 1;
  61. kk[3 * (i / 9 / 3) + (i % 9 / 3)][a[i] - '0'] = 1; //初始化
  62. }
  63. }
  64. dfs(0, 0);
  65. }
  66. return 0;
  67. }

  

  1.  

数独:dfs+剪枝+位运算+排除冗余+优化搜索顺序(未完)的更多相关文章

  1. POJ - 3074 Sudoku (搜索)剪枝+位运算优化

    In the game of Sudoku, you are given a large 9 × 9 grid divided into smaller 3 × 3 subgrids. For exa ...

  2. 模拟赛T5 : domino ——深搜+剪枝+位运算优化

    这道题涉及的知识点有点多... 所以还是比较有意思的. domino 描述 迈克生日那天收到一张 N*N 的表格(1 ≤ N ≤ 2000),每个格子里有一个非 负整数(整数范围 0~1000),迈克 ...

  3. iis7 64位 操作excel的一系列问题(未完待续)

    查了半天发现是IIS跑在64位环境下引起的.而64位下,是木有Access数据库的驱动的(包括Excel也不行). 解决办法是:在目标网站的应用程序池中选择高级设置,然后将启用32位应用程序设置为tr ...

  4. CSS写作建议和性能优化总结(未完待续)

    这里是我从网上的一篇文章看过来的,这里先做一点小结,之后再补充. 1.CSS渲染规则 今天在微博的一篇文章上看到的,之前我都以为渲染是从左往右渲染.发现我的想法是错的.之所以采用从右往左的渲染规则,是 ...

  5. [洛谷P1731][NOI1999]生日蛋糕(dfs)(剪枝)

    典型的深搜+剪枝策略 我们采用可行性剪枝.上下界剪枝.优化搜索顺序剪枝.最优性剪枝的方面来帮助我们进行剪枝. 也许有人还不知道剪枝,那我就弱弱地为大家补习一下吧qwq: .优化搜索顺序: 在一些搜索问 ...

  6. poj1011 Sticks (dfs剪枝)

    [题目描述] George took sticks of the same length and cut them randomly until all parts became at most 50 ...

  7. HDU - 2276 位运算矩阵快速幂

    挺有意思的一道题 要会运用一些常见的位运算操作进行优化 题目的本质就是要求下面的式子 \(dp[i][j+1]=(dp[i-1][j]+dp[i][j]) \mod 2\) (第\(i\)个字符在\( ...

  8. bitset 位运算

    1. 判断一个数是否是2的方幂n > 0 && ((n & (n - 1)) == 0 ) 解释((n & (n-1)) == 0): 如果A&B==0, ...

  9. 数独求解问题(DFS+位运算优化)

    In the game of Sudoku, you are given a large 9 × 9 grid divided into smaller 3 × 3 subgrids. For exa ...

随机推荐

  1. Dokcer-ce安装脚本

    安装docker #!/bin/bash # coding: utf- # Copyright (c) set -e #返回值为0时,退出脚本 echo "1. 备份yum" { ...

  2. HTML中IMG标签总结

    一.Img标签有两个重要的属性: 1.src  属性:图片的地址 2.alt  属性:图片不显示是现实的文字 二.Img标签是行级元素: img.input属于行内替换元素.height/width/ ...

  3. C++读取字符串数据的两种方式

    C++读取字符串数据的两种方式 对于同样的样例输入: ladder came tape soon leader acme RIDE lone Dreis peat ScAlE orb eye Ride ...

  4. LightOJ 1203--Guarding Bananas(二维凸包+内角计算)

    1203 - Guarding Bananas    PDF (English) Statistics Forum Time Limit: 3 second(s) Memory Limit: 32 M ...

  5. 【若泽大数据实战第二天】Linux命令基础

    Linux基本命令: 查看IP: ifconfig 或者 hostname -i(需要配置文件之后才可以使用) ipconfig(Windows) 关闭防火墙: Service iptables st ...

  6. ubuntu下安装应用(搜狗输入法)

  7. python打印九九乘法表

    每种编程语言都可能会遇到编写“九九乘法表”的问题,用Python来处理也是很简单的,具体代码如下(基于Python3)): i = 1 while i <= 9: j = 1 while j & ...

  8. python 基于Anaconda import numpy 报错 Importing the multiarray numpy extension module failed.

    在windows中安装了 Anaconda 运行时报错 原因是系统环境变量起初并没有引入 E:\Tools\Anaconda\Library\bin 解决办法: 在系统环境变量中加入    E:\To ...

  9. python 新手函数基础(函数定义调用值传递等)

    1.编程的集中主要方式: 面向过程 >类 >>关键字class 面向函数>函数 >> 关键字def 面向过程> 过程 >> 关键字def 2.py ...

  10. Linux字符设备驱动--No.2

    分析中断注册函数:request_irq int butsOpen(struct inode *p, struct file *f) { int irq; int i; ; printk(KERN_E ...