zoukankan      html  css  js  c++  java
  • 【HDU】2780 SuSuSudoku

      1 #include<cstdio>
      2 #include<cstring>
      3 #define MAXM 10
      4 #define MAXL 324
      5 #define MAXN 240000
      6 #define INF 0x7FFFFFFF
      7 char sd[MAXM][MAXM];
      8 int L[MAXN], R[MAXN], U[MAXN], D[MAXN], H[MAXN];
      9 int size, C[MAXN], S[MAXN], X[MAXN], Q[MAXN], vis[MAXL * 3];
     10 void Read()
     11 {
     12     int i, j;
     13     for (i = 1; i < MAXM; i++)
     14     {
     15         for (j = 1; j < MAXM; j++)
     16             scanf(" %c", &sd[i][j]);
     17     }
     18 }
     19 void Init()
     20 {
     21     int i;
     22     for (i = 0; i <= MAXL; i++)
     23     {
     24         L[i + 1] = i;
     25         R[i] = i + 1;
     26         U[i] = D[i] = i;
     27         S[i] = 0;
     28     }
     29     R[MAXL] = 0;
     30     size = MAXL + 1;
     31 }
     32 void Remove(int c)
     33 {
     34     int i, j;
     35     L[R[c]] = L[c];
     36     R[L[c]] = R[c];
     37     for (i = D[c]; i != c; i = D[i])
     38     {
     39         for (j = R[i]; j != i; j = R[j])
     40         {
     41             U[D[j]] = U[j];
     42             D[U[j]] = D[j];
     43             S[C[j]]--;
     44         }
     45     }
     46 }
     47 void Resume(int c)
     48 {
     49     int i, j;
     50     L[R[c]] = c;
     51     R[L[c]] = c;
     52     for (i = D[c]; i != c; i = D[i])
     53     {
     54         for (j = R[i]; j != i; j = R[j])
     55         {
     56             U[D[j]] = j;
     57             D[U[j]] = j;
     58             S[C[j]]++;
     59         }
     60     }
     61 }
     62 inline void Link(int r, int c)
     63 {
     64     D[size] = D[c];
     65     U[size] = c;
     66     U[D[c]] = size;
     67     D[c] = size;
     68     if (H[r] < 0)
     69         H[r] = L[size] = R[size] = size;
     70     else
     71     {
     72         L[size] = H[r];
     73         R[size] = R[H[r]];
     74         L[R[H[r]]] = size;
     75         R[H[r]] = size;
     76     }
     77     S[c]++;
     78     X[size] = r;
     79     C[size++] = c;
     80 }
     81 bool Dance(int now)
     82 {
     83     int i, j, c, temp;
     84     if (R[0] == 0)
     85         return true;
     86     for (temp = INF,i = R[0]; i; i = R[i])
     87     {
     88         if (S[i] < temp)
     89         {
     90             temp = S[i];
     91             c = i;
     92         }
     93     }
     94     Remove(c);
     95     for (i = D[c]; i != c; i = D[i])
     96     {
     97         vis[X[i]] = true;
     98         for (j = R[i]; j != i; j = R[j])
     99             Remove(C[j]);
    100         if (Dance(now + 1))
    101             return true;
    102         for (j = L[i]; j != i; j = L[j])
    103             Resume(C[j]);
    104         vis[X[i]] = false;
    105     }
    106     Resume(c);
    107     return false;
    108 }
    109 int main()
    110 {
    111     int i, j, k, r, ca;
    112     scanf("%d", &ca);
    113     while (ca--)
    114     {
    115         Read();
    116         Init();
    117         for (r = 0, i = 1; i < MAXM; i++)
    118         {
    119             for (j = 1; j < MAXM; j++)
    120             {
    121                 if (sd[i][j] == '0')
    122                 {
    123                     for (k = 1; k < MAXM; k++)
    124                     {
    125                         H[++r] = -1;
    126                         Q[r] = k;
    127                         Link(r, (i - 1) * 9 + k);
    128                         Link(r, 81 + (j - 1) * 9 + k);
    129                         Link(r, 162 + ((i - 1) / 3 * 3 + (j - 1) / 3) * 9 + k);
    130                         Link(r, 243 + (i - 1) * 9 + j);
    131                     }
    132                 }
    133                 else
    134                 {
    135                     H[++r] = -1;
    136                     k = sd[i][j] - '0';
    137                     Q[r] = k;
    138                     Link(r, (i - 1) * 9 + k);
    139                     Link(r, 81 + (j - 1) * 9 + k);
    140                     Link(r, 162 + ((i - 1) / 3 * 3 + (j - 1) / 3) * 9 + k);
    141                     Link(r, 243 + (i - 1) * 9 + j);
    142                 }
    143             }
    144         }
    145         memset(vis, false, sizeof(vis));
    146         if (Dance(0))
    147         {
    148             for (k = 0, i = 1; i <= r; i++)
    149             {
    150                 if (vis[i])
    151                 {
    152                     k++;
    153                     printf("%d", Q[i]);
    154                     if (k % 9 == 0)
    155                         putchar('\n');
    156                 }
    157             }
    158         }
    159         else
    160             puts("Could not complete this grid.");
    161         if (ca)
    162             putchar('\n');
    163     }
    164     return 0;
    165 }
  • 相关阅读:
    解决HbuilderX乱码问题
    IDEA
    关于Git开发的一些注意事项
    postgresql
    启动新拉取项目流程
    关于能发布但无法打包的问题
    关于人脸感知设备(类似门禁考勤设备)搜索添加显示成功但却添加不上的问题
    在GitLab上创建项目并上传初始文件
    中控标替换成白标开发
    工厂模式
  • 原文地址:https://www.cnblogs.com/DrunBee/p/2607099.html
Copyright © 2011-2022 走看看