例题1.14 填充正方形 UVa11520

1.题目描述:点击打开链接

2.解题思路:本题要求字典序最小,由于n的范围比较小,直接尝试按照字典序填写每个格子即可。

3.代码:

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<algorithm>
#include<string>
#include<sstream>
#include<set>
#include<vector>
#include<stack>
#include<map>
#include<queue>
#include<deque>
#include<cstdlib>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<ctime>
#include<functional>
using namespace std;

#define N 10+5
char g[N][N];
int dx[] = { 1, -1, 0, 0 };
int dy[] = { 0, 0, 1, -1 };
int vis[26];
int n;
bool is_inside(int r, int c)
{
	if (r < 0 || r >= n || c < 0 || c >= n)return false;
	return true;
}
void dfs(int cur)
{
	if (cur == n*n)
	{
		for (int i = 0; i < n;i++)
		for (int j = 0; j < n; j++)
			printf("%c%s", g[i][j], j == n - 1 ? "\n" : "");
		return;
	}
	int r = cur / n, c = cur%n;
	if (g[r][c] == '.')
	{
		memset(vis, 0, sizeof(vis));
		for (int d = 0; d < 4; d++)
		{
			int nx = r + dx[d], ny = c + dy[d];
			if (is_inside(nx, ny) && isupper(g[nx][ny]))//找周围的字母
				vis[g[nx][ny] - 'A'] = 1;
		}
		for (int i = 0; i<26; i++)//找字典序最小的字母
		if (!vis[i]){ g[r][c] = i + 'A'; break; }
	}
	dfs(cur + 1);
}
int main()
{
	//freopen("t.txt", "r", stdin);
	int T;
	cin >> T;
	for (int rnd = 1; rnd <= T; rnd++)
	{
		scanf("%d", &n);
		for (int i = 0; i < n; i++)
			scanf("%s", g[i]);
		printf("Case %d:\n",rnd);
		dfs(0);
	}
	return 0;
}
时间: 2024-08-17 23:42:44

例题1.14 填充正方形 UVa11520的相关文章

Uva 11520 填充正方形

题目链接:https://vjudge.net/problem/UVA-11520 题意: 给定一个n*n的正方形,把剩下的格子中填满大写字母,任意两个相邻的格子字母不同,要求最后字典序最小: 分析: 第一想法回溯啊,当然是不对的,100个点回溯会死人的! 其实,可以发现,每个点不可能说,由于前面的决策,后来不能满足了,相邻的点有4个,我有26个英文字母. 1 #include <bits/stdc++.h> 2 3 using namespace std; 4 5 const int max

填充正方形

题目描述 已知矩形的大小为n×m,现用a×a的正方形填充该矩形.输入三个正整数n,m,a(n,m,a≤10^9),计算至多能填入多少正方形?(正方形可以正好碰到矩形边界,但不能超出矩形外) 输入 一行三个用一个空格隔开的正整数n,m,a. 输出 输出能填入正方形的数量. 样例输入 3 4 1 样例输出 12 数据范围限制 1<=n,m,a≤10^9 #include<iostream> #include<string> using namespace std; int mai

Uva 填充正方形

暴力出奇迹 1 #include<iostream> 2 #include<cstdio> 3 using namespace std; 4 5 const int maxn=10+5; 6 int T,n; 7 char S[maxn][maxn]; 8 9 int main() 10 { 11 cin>>T; 12 for(int kase=1;kase<=T;kase++) 13 { 14 cin>>n; 15 for(int i=0;i<

例题3.14 出现次数最多的子串 LA4670

1.题目描述:点击打开链接 2.解题思路:本题利用AC自动机解决.本题给的文本串非常长,但是模板串又多而短,正好适合AC自动机.然而一个问题是如何统计出现的次数.这里直接在print函数中递归统计.<训练指南>上说因为有重复的模板,需要用一个map来索引,但是本题由于已经把所有的模板保存到P数组了,没有这个索引也可以做. 3.代码: #include<iostream> #include<algorithm> #include<cassert> #inclu

填充几何图形

使用GD2函数不仅可以绘制线条图形,而且可以绘制填充图形,如填充圆形,填充矩形等.下面对GD2中常用的填充图形的绘制方法进行介绍. bool imagefill( resource image, int x, int y, int color ) imagefill()函数在image图像的坐标( x, y ) (图像的左上角为(0,0))处用color颜色执行区域填充(即与(x,y)点颜色相同切相邻的点都会被填充). bool imagefilledarc ( resource image ,

[计算机图形学 with OpenGL] Chapter10 OpenGL三维观察程序示例

10.10节书中给出了一个程序示例,有一个填充正方形,从侧面的角度观察并画到屏幕上. 图0 这里进一步画出一个立方体,将相机放入立方体中心,旋转相机,达到在立方体中旋转看到不同画面的效果. 步骤: 1 使用的是4.9节中的OpenGL顶点数组方法.创建一个立方体100*100*100,坐标范围(0, 0, 0)到(100, 100, 100). 2 立方体各面使用不同的颜色,调整顶点顺序以确保相机看到的都是填充面而不是线框图. 3 将投影观察点(即观察系原点)设置在矩形中心P0 = (50, 5

Hibernate 查询方式(HQL/QBC/QBE)汇总

作为老牌的 ORM 框架,Hibernate 在推动数据库持久化层所做出的贡献有目共睹. 它所提供的数据查询方式也越来越丰富,从 SQL 到自创的 HQL,再到面向对象的标准化查询. 虽然查询方式有点眼花缭乱,配置使用起来也稍微有点复杂. 但是丝毫掩盖不了它迷人的地方,本篇博客试着汇总 Hibernate 所有的查询方式. 萝卜青菜各有所爱,工作中可以根据自己的喜好选择其中的几种进行编程. 1. HQL 方式,参数使用问号占位(4.1 版本中已被废弃) public List<UserPO>

坐标轴的平移和旋转

<!DOCTYPE html > <html> <head> <meta charset="gb2312" /> <title>canvas 旋转</title> <script type="text/javascript" src="js1.js"></script> </head> <body > <canvas id

Python系列5之模块

模块 1. 模块的分类 模块,又称构件,是能够单独命名并独立地完成一定功能的程序语句的集合(即程序代码和数据结构的集合体). (1)自定义模块 自己定义的一些可以独立完成某个功能的一段程序语句,可以是一个文件,也可以是一个目录. (2)第三方模块 是由其他人写的一些程序语句,我们可以用它来实现自己的功能. (3)内置模块 是由python自己带的一些实现某种特定功能的组件. 2. 模块的导入 (1)python默认的模块寻找路径 当开始导入一个模快的时候,python默认的会先找到第一个路径去看