这两天OD留的题是搜索,这个东西,就是历年的NOIP压轴题嘛。做了几道什么斗地主啊啥的,感觉还是这题我还懂点。

这道题的搜(xia)索(da)思路是这样的:预处理出一切能处理的东西。

数独大家都了解吧:每一行,每一列,每一个九宫格都要求不一样。

我们需要预处理出:

每个点的分数(废话)。每一行中确定的数。每一列中确定的数。每一个九宫格中确定的数。以及最开始确定部分的答案。

记录每个未确定点的坐标。搜他们就好啦(倒着搜一定要。我哪知道为啥)

对于每个点,就纯循环枚举1~9就好了。当然我们要判断剪枝。

当这行有这个数的时候,return

……

以此类推。

这样就算搜到重的也一下就退回来了。

还有,记得要回溯。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<cmath>
using namespace std;
#define pos(i,a,b) for(int i=(a);i<=(b);i++)
#define pos2(i,a,b) for(int i=(a);i>=(b);i--)
#define N 200
#define inf 0x7fffffff
#define LL long long
int a[N][N],point[N][N];
int hang[N][N],lie[N][N],ge[N][N],cnt[N][N];
int ans,basic,ji=0;
struct haha{
	int x,y;
}fei[100];
void init(){
	point[5][5]=10;
	pos(i,1,9) point[1][i]=point[9][i]=point[i][1]=point[i][9]=6;
	pos(i,2,8) point[2][i]=point[8][i]=point[i][2]=point[i][8]=7;
	pos(i,3,7) point[3][i]=point[7][i]=point[i][3]=point[i][7]=8;
	pos(i,4,6) point[4][i]=point[6][i]=point[i][4]=point[i][6]=9;
	ji=0;
	pos(i,1,3){
		pos(j,1,3){
			cnt[i][j]=++ji;
		}
	}
	ji=0;
	pos(i,1,9){
		pos(j,1,9){
			scanf("%d",&a[i][j]);
			if(a[i][j]!=0){
				basic+=a[i][j]*point[i][j];//cout<<basic<<endl;
				hang[i][a[i][j]]=1;lie[j][a[i][j]]=1;
				int temp=i/3;temp+=i%3==0?0:1;int temp2=j/3;temp2+=j%3==0?0:1;
				ge[cnt[temp][temp2]][a[i][j]]=1;
			}
			else{fei[++ji].x=i;fei[ji].y=j;}
		}
	}
}
void dfs(int last,int sum,int num){
	if(hang[fei[last].x][num]==1) return;
	if(lie[fei[last].y][num]==1) return;
	int temp=fei[last].x/3;temp+=fei[last].x%3==0?0:1;int temp2=fei[last].y/3;temp2+=fei[last].y%3==0?0:1;
	if(ge[cnt[temp][temp2]][num]==1) return;
	if(last==1){ans=max(ans,sum);return;}
	//cout<<last<<"   sum="<<sum<<"  num="<<num<<endl;
	pos(i,1,9){
		hang[fei[last].x][num]=1;lie[fei[last].y][num]=1;ge[cnt[temp][temp2]][num]=1;
		dfs(last-1,sum+(i*point[fei[last-1].x][fei[last-1].y]),i);
		hang[fei[last].x][num]=0;lie[fei[last].y][num]=0;ge[cnt[temp][temp2]][num]=0;
	}
}
int main(){
	//freopen("sudoku.in","r",stdin);
	//freopen("sudoku.out","w",stdout);
	init();
	//cout<<"ji="<<ji<<endl;
	pos(i,1,9)
		dfs(ji,i*point[fei[ji].x][fei[ji].y],i);
	if(ans==0)  cout<<"-1";
	else	cout<<basic+ans;
	return 0;
}

[NOIP2009] 靶形数独 骚气的大爆搜的更多相关文章

  1. NOIP2009靶形数独[DFS 优化]

    描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z博士请教,Z 博士拿出了他最近发明的“靶形数独 ...

  2. [NOIP2009]靶形数独 题解

    407. [NOIP2009] 靶形数独 时间限制:5 s   内存限制:128 MB [问题描述] 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低. ...

  3. [NOIP2015] 斗地主 大爆搜

    考试的时候想了半天,实在是想不到解决的办法,感觉只能暴力..然后暴力也懒得打了,小数据模拟骗30分hhh 然而正解真的是暴力..大爆搜.. 然后我的内心拒绝改这道题(TAT) 不过在wcx大佬的帮助下 ...

  4. [NOIP2009] 靶形数独(搜索+剪枝)

    题目描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他 们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z 博士请教, Z 博士拿出了他最近发明的 ...

  5. NOIP2009 靶形数独

    4.靶形数独 (sudoku.pas/c/cpp) [问题描述] 小城和小华都是热爱数学的好学生, 近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了, ...

  6. NOIP2009靶形数独

    题目描述: 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z 博士请教,Z 博士拿出了他最近发明的“ ...

  7. [NOIP2009]靶形数独 深搜+枝杈优化

    这道题,又是一位玄学搜索...... 我是用的蜗牛序搜的(顾名思义,@,这么搜),我正着搜80然后一反转比原来快了几十倍........一下AC....... 我的思路是这样的话我们可以从内到外或者从 ...

  8. [NOIP2009] 靶形数独(搜索)

    P1074 靶形数独 题目描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向 Z 博士请教,Z 博士 ...

  9. NOIP2009靶形数独(暴搜)

    题目传送门 题目描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向Z博士请教,Z博士拿出了他最近发明 ...

随机推荐

  1. 【从零开始】用node搭建一个jsonp&json服务

    目录: 一.介绍 二.node安装 三.webstorm配置node环境 四.代码介绍 五.如何使用 六.自定义域名 七.其他 一.介绍 1.背景     日常工作中,跟后端商定好接口格式后:通常采用 ...

  2. 【Android Developers Training】 89. 最大化的使用谷歌云消息(Google Cloud Messaging)

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  3. Java基础(5)- 输出输入

    输出输入 public class Input { public static void main (String[] args){ try { /** * 打开文件流进行读取 */ Scanner ...

  4. C# 文字转换最简单的方法

    引用Microsoft.VisualBasic string text=Strings.StrConv("需要转换的文字", VbStrConv.TraditionalChines ...

  5. Android端恶意锁屏勒索应用分析

    一.前言 5月12日,一场全球性互联网灾难悄然而至,一款名为WannaCRY的PC端恶意勒索软件利用NSA泄漏的危险漏洞“永恒之蓝”,给100多个国家和地区10万台电脑造成了巨大的损失.到2017年为 ...

  6. vijos1056题解

    题目: 桌面上放了N个平行于坐标轴的矩形,这N个矩形可能有互相覆盖的部分,求它们组成的图形的面积. 在翻题目时,偶然发现了这道标号为WA的题目. 原来,以前我把一中培训的代码发了上去,却WA了4个点, ...

  7. Watson API - Personality Insight For Certificate

    Personality Insight For Certificate 1.Describe the intended use of the Personality Insights service ...

  8. FineReport中如何对cpt模板加密

    1. 描述 FR客户使用FineReport报表并将其集成到自己的产品中,然后提供给最终用户使用,最终用户可以预览FR模板,但是不能打开模板进行设计修改. FineReport提供了cpt模板Des加 ...

  9. PCI_Making Recommendations

    协作性过滤 简单理解从众多用户中先搜索出与目标用户'品味'相似的部分人,然后考察这部分人的偏爱,根据偏爱结果为用户做推荐.这个过程也成为基于用户的协作性过滤(user_based collaborat ...

  10. 禁用Ubuntu 15.04登录界面显示客人会话

    在控制台打开如下配置文件,如果没有就自己创建一个: sudo vi /etc/lightdm/lightdm.conf 向文件中添加如下内容: [SeatDefaults] greeter-sessi ...