poj2965

poj2965

dfs,O(2^16)

 

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
using namespace std;

bool map[4][4];
int ans[16];

void init()
{
	int i, j;

	for (i = 0; i < 4; i++)
	{
		for (j = 0; j < 4; j++)
		{
			char ch;
			cin >> ch;
			if (ch == '-')
				map[i][j] = true;
			else
				map[i][j] = false;
		}
		getchar();
	}
}

void operate(int x, int y)
{
	if (x < 0 || y < 0 || x > 3 || y > 3)
		return;
	map[x][y] = !map[x][y];
}

void turn(int pos)
{
	ans[pos] = !ans[pos];
	int x = pos / 4;
	int y = pos % 4;
	int i;
	operate(x, y);
	for (i = 1; i < 4; i++)
	{
		operate(x + i, y);
		operate(x, y + i);
		operate(x - i, y);
		operate(x, y - i);
	}
}

bool finished()
{
	int tot = 0;
	int i;
	for (i = 0; i < 16; i++)
		tot += map[i / 4][i % 4];
	return (tot == 16);
}

void output()
{
	int i;
	for (i = 0; i < 16; i++)
	{
		if (ans[i])
			printf("%d %d\n", i / 4 + 1, i % 4 + 1);
	}
}

void dfs(int pos, int step)
{
	if (finished())
	{
		cout << step << endl;
		output();
		exit(0);
		return;
	}
	if (pos >= 16)
		return;
	dfs(pos + 1, step);
	turn(pos);
	dfs(pos + 1, step + 1);
	turn(pos);//这句忘了写,导致错误
}

int main()
{
	//freopen("D:\\t.txt", "r", stdin);
	init();
	dfs(0, 0);

	return 0;
}

转载于:https://www.cnblogs.com/rainydays/archive/2011/02/01/1948683.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/110664.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 23种设计模式对应应用场景

    23种设计模式对应应用场景

    2021年10月2日
    41
  • 关于用户路径分析模型_spark用户行为分析

    关于用户路径分析模型_spark用户行为分析一、需求背景在互联网数据化运营实践中,有一类数据分析应用是互联网行业所独有的——路径分析。路径分析应用是对特定页面的上下游进行可视化展示并分析用户在使用产品时的路径分布情况。比如:当用户使用某APP时,是怎样从【首页】进入【详情页】的,用户从【首页】分别进入【详情页】、【播放页】、【下载页】的比例是怎样的,以及可以帮助我们分析用户离开的节点是什么。在场景对应到具体的技术方案设计上,我们将访问数据根据session划分,挖掘出用户频繁访问的路径;功能上允许用户即时查看所选节点相关路径,支持用户自定义设

    2022年8月24日
    5
  • The Eigenvalues and Eigenvectors of Tridiagonal Toeplitz Matrix「建议收藏」

    The Eigenvalues and Eigenvectors of Tridiagonal Toeplitz Matrix「建议收藏」一般来说,我们都是先求一个矩阵的特征值,然后再求它的特征向量。但对于某种特殊的矩阵来说,先求特征向量反而更加方便,现在就让我们一起来看下吧!

    2025年5月31日
    3
  • Navicat15.0.23 激活码(破解版激活)

    Navicat15.0.23 激活码(破解版激活),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    165
  • JAVA实现的小程序[通俗易懂]

    JAVA实现的小程序[通俗易懂]下面介绍一些JAVA实现的一些小程序!!!感兴趣的小伙伴可以点击链接,其中有教程和源码哦!一、JAVA实现雪花飘落首先我们先看效果,雪花是流动的,从上往下,依次变大,十分浪漫!(效果是动态的)二、JAVA实现小球弹跳首先,我们来看效果,一共五个颜色不相同的球,每撞击一下边界,分数加1,分数越大,球的速度越快。(效果是动态的)三、JAVA实现打字小游戏首先我们先看效果,左上角的分数是用来记录我们打对了多少字母。字母是从上面开始往下落。每打对一个字母,分数增加,增加.

    2022年7月9日
    20
  • Verycd网站中不能显示下载网址的解决办法[通俗易懂]

    Verycd网站中不能显示下载网址的解决办法[通俗易懂]在verycd.com搜索资源的时候,有时候一些权利资源会出现“该内容尚未提供权利证明,无法提供下载”的版权声明。当你急着找这些资源的话,出现这个问题肯定非常烦人的,那该如何解决呢?方法其实很简单。方法0:安装浏览器Verycd链接显示的插件火狐的插件地址(安装这个插件后,可以直接在verycd上看到下载地址):https://addons.mozilla.org/zh-TW/fire

    2022年8月10日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号