ai2813-画家问题-回溯解法C语言
2017-04-11 00:49
225 查看
方法粗陋,时间略长,还望指教。
#include <stdio.h>
#include <stdlib.h>
int mintimes=225;
int nowtimes=0;
void collor(int*a)
{
*a?(*a=0):(*a=1);
}
void change(int*now,int size)
{
collor(now);
collor(now+1);
collor(now-1);
collor(now+size+2);
collor(now-size-2);
}
void searchf(int i,int size,int*wall,int*record)//穷举第一行i~n的所有可能
{
void paint(int*wall,int n,int*record);
if(i<=size)
{
searchf(i+1,size,wall,record);
change(wall+size+2+i,size);
*(record+(size+2)+i)=1;
searchf(i+1,size,wall,record);
change(wall+size+2+i,size);
*(record+(size+2)+i)=0;
}
else
paint(wall,size,record);
}
void paint(int*wall,int n,int*record)
{ int flag=0,i,j;
for(i=1;i<n;i++)
{
for(j=1;j<n+1;j++)
{
if(*(wall+i*(n+2)+j)==0)
{
change(wall+(i+1)*(n+2)+j,n);
*(record+(i+1)*(n+2)+j)=1;
nowtimes++;
}
}
}
for(i=1;i<n+1;i++)
{
flag+=*(wall+n*(n+2)+i);
nowtimes+=*(record+(n+2)+i);
}
if(flag==n&&nowtimes<mintimes)
mintimes=nowtimes;
for(i=2;i<=n;i++)
{
for(j=1;j<n+1;j++)
{
if(*(record+i*(n+2)+j)==1)
{
change(wall+i*(n+2)+j,n);
*(record+i*(n+2)+j)=0;
}
}
}
nowtimes=0;
}
int main()
{
int n,i,j;
scanf("%d",&n);
int paint[n+2][n+2],record[n+2][n+2];
for(i=1;i<n+1;i++)
for(j=1;j<n+1;j++)
record[i][j]=0;
char wall[n+2][n+2];
for(i=1;i<n+1;i++)
{
scanf("%s",&wall[i][1]);
for(j=1;j<n+1;j++)
(wall[i][j]=='w')?(paint[i][j]=0):(paint[i][j]=1);
}
searchf(1,n,paint[0],record[0]);
(mintimes>200)?(printf("inf")):(printf("%d",mintimes));
return 0;
}
#include <stdio.h>
#include <stdlib.h>
int mintimes=225;
int nowtimes=0;
void collor(int*a)
{
*a?(*a=0):(*a=1);
}
void change(int*now,int size)
{
collor(now);
collor(now+1);
collor(now-1);
collor(now+size+2);
collor(now-size-2);
}
void searchf(int i,int size,int*wall,int*record)//穷举第一行i~n的所有可能
{
void paint(int*wall,int n,int*record);
if(i<=size)
{
searchf(i+1,size,wall,record);
change(wall+size+2+i,size);
*(record+(size+2)+i)=1;
searchf(i+1,size,wall,record);
change(wall+size+2+i,size);
*(record+(size+2)+i)=0;
}
else
paint(wall,size,record);
}
void paint(int*wall,int n,int*record)
{ int flag=0,i,j;
for(i=1;i<n;i++)
{
for(j=1;j<n+1;j++)
{
if(*(wall+i*(n+2)+j)==0)
{
change(wall+(i+1)*(n+2)+j,n);
*(record+(i+1)*(n+2)+j)=1;
nowtimes++;
}
}
}
for(i=1;i<n+1;i++)
{
flag+=*(wall+n*(n+2)+i);
nowtimes+=*(record+(n+2)+i);
}
if(flag==n&&nowtimes<mintimes)
mintimes=nowtimes;
for(i=2;i<=n;i++)
{
for(j=1;j<n+1;j++)
{
if(*(record+i*(n+2)+j)==1)
{
change(wall+i*(n+2)+j,n);
*(record+i*(n+2)+j)=0;
}
}
}
nowtimes=0;
}
int main()
{
int n,i,j;
scanf("%d",&n);
int paint[n+2][n+2],record[n+2][n+2];
for(i=1;i<n+1;i++)
for(j=1;j<n+1;j++)
record[i][j]=0;
char wall[n+2][n+2];
for(i=1;i<n+1;i++)
{
scanf("%s",&wall[i][1]);
for(j=1;j<n+1;j++)
(wall[i][j]=='w')?(paint[i][j]=0):(paint[i][j]=1);
}
searchf(1,n,paint[0],record[0]);
(mintimes>200)?(printf("inf")):(printf("%d",mintimes));
return 0;
}
相关文章推荐
- [算法]经典算法8皇后(N皇后)问题的解法,C语言实现
- [算法]简单的背包问题递归解法,C语言实现
- 皇后问题最快的解法(C语言)八皇后、十六皇后时间在毫秒级
- 八皇后问题回溯解法
- [算法]数据结构算法背包问题解法之递归解法,C语言实现
- C语言中的素数环问题(回溯)//函数exit的使用
- 一种便于理解的8皇后问题的回溯解法
- Queen 八皇后问题 回溯经典解法
- 回溯算法 8皇后问题的一种解法 适合初学者观察整个回溯的过程
- C语言 递归(回溯) 解决数独问题
- 回溯法-旅行售货员问题(C语言)
- C语言求Fibonacci斐波那契数列通项问题的解法总结
- C语言回溯法装载问题
- c语言考试中 火车进出站的问题解法是什么
- N皇后问题的一般解法--回溯法
- C语言经典弱智问题解法整理
- C语言 递归(回溯) 解决数独问题
- C语言魔板问题递归解法
- 迷宫问题--非递归回溯 C语言实现
- 算法学习笔记(二)——01背包问题之回溯解法