P1074 靶形数独 - 40

#include <bits/stdc++.h>
#define searchnext(x, y) y == 9 ? search(x + 1, 1) : search(x, y + 1)
using namespace std;
long long ans = 0;
int a[10][10];
void search(int, int);
void calc() {
  long long tmp = 0;
  for (int i = 1; i <= 9; i++) {
    for (int j = 1; j <= 9; j++) {
      if (i == 1 || i == 9 || j == 1 || j == 9) {
        tmp += 6 * a[i][j];
      } else if (abs(i - 9) == 1 || abs(i - 9) == 7 || abs(j - 9) == 1 ||
                 abs(j - 9) == 7) {
        tmp += 7 * a[i][j];
      } else if (abs(i - 9) == 2 || abs(i - 9) == 6 || abs(j - 9) == 2 ||
                 abs(j - 9) == 6) {
        tmp += 8 * a[i][j];
      } else if (abs(i - 9) == 5 || abs(i - 9) == 3 || abs(j - 9) == 5 ||
                 abs(j - 9) == 3) {
        tmp += 9 * a[i][j];
      } else
        tmp += 10 * a[i][j];
    }
  }
  ans = max(ans, tmp);
}
bool pd(int x, int y, int k) {
  for (int i = 1; i <= 9; i++)
    if (a[x][i] == k || a[i][y] == k)
      return 0;
  for (int i = (x - 1) / 3 * 3 + 1; i <= (x - 1) / 3 * 3 + 3; i++)
    for (int j = (y - 1) / 3 * 3 + 1; j <= (y - 1) / 3 * 3 + 3; j++)
      if (a[i][j] == k)
        return 0;
  return 1;
}
void search(int x, int y) {
  if (x == 10 && y == 1)
    calc();
  if (a[x][y] != 0) {
    searchnext(x, y);
  } else {
    for (int i = 9; i >= 1; i--)
      if (pd(x, y, i)) {
        a[x][y] = i;
        searchnext(x, y);
        a[x][y] = 0;
      }
  }
}
int main() {
  freopen("input.in", "r", stdin);
  for (int i = 1; i <= 9; i++)
    for (int j = 1; j <= 9; j++)
      scanf("%d", &a[i][j]);
  search(1, 1);
  if (ans)
    cout << ans;
  else
    cout << -1;
  return 0;
}

posted on   蒟蒻konjac  阅读(158)  评论(0编辑  收藏  举报

编辑推荐:
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
阅读排行:
· 从零开始开发一个 MCP Server!
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时
· Browser-use 详细介绍&使用文档
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示