POJ 1077 Eight

题意:经典的八数码=3=

3*3的格子,里面有1~8这8个数字,还有一个空格x,移动空格的位置,直到移到1~8按顺序排好,输出移动的序列。

 

解法:看到题果断写了个广搜……然后T了……百度了一下说广搜虽然慢了点但是也是可以过的嘛……默默看了眼自己代码……唔……好像他们都不是用string路径的……

实在懒得改了,学个新做法吧,哦吼吼吼这个A*看起来很神奇啊……学一下学一下

600ms+过了……嗯……跟别人广搜一个时间啊……_(:з」∠)_实在不想改记路径的方法啊……

A*我觉得就是一个更聪明的广搜……每个状态的权值为每个数到最终状态的曼哈顿距离之和加上已走过的步长,用优先队列维护……

还有就是每个状态序列可以转换成一个排列的id……涨姿势了0v0

 

代码:

#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
#include<math.h>
#include<limits.h>
#include<time.h>
#include<stdlib.h>
#include<map>
#include<queue>
#include<set>
#include<stack>
#include<vector>
#define LL long longusing namespace std;int fac[] = { 1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880 };
int order(vector <int> v) {int i, j, temp, num;num = 0;for (i = 0; i < 8; i++) {temp = 0;for (j = i + 1; j < 9; j++) {if (v[j] < v[i])temp++;}num += fac[v[i] -1] * temp;}return num;
}
bool vis[400000];
int dir1[4][2] = {-1, 0, 1, 0, 0, -1, 0, 1};
char dir2[] = "udlr";
struct node
{vector <int> v;string path;node(vector <int> tv, string tpath){v = tv;path = tpath;}node() {}bool operator < (const node &tmp) const{int sum1 = 0, sum2 = 0;for(int i = 0; i < 9; i++)sum1 += abs((v[i] - 1) / 3 - i / 3) + abs((v[i] - 1) % 3 - i % 3);for(int i = 0; i < 9; i++)sum2 += abs((tmp.v[i] - 1) / 3 - i / 3) + abs((tmp.v[i] - 1) % 3 - i % 3);return sum1 + path.size() > sum2 + tmp.path.size();}
};
string bfs(vector <int> st)
{memset(vis, 0, sizeof vis);vis[order(st)] = 1;priority_queue <node> q;q.push(node(st, ""));while(!q.empty()){node tmp = q.top();if(order(tmp.v) == 0) return tmp.path;q.pop();int sx, sy;for(int i = 0; i < 3; i++)for(int j = 0; j < 3; j++)if(tmp.v[i * 3 + j] == 9){sx = i;sy = j;}for(int i = 0; i < 4; i++){int tx = sx + dir1[i][0], ty = sy + dir1[i][1];if(tx < 0 || tx > 2 || ty < 0 || ty > 2) continue;swap(tmp.v[tx * 3 + ty], tmp.v[sx * 3 + sy]);int id = order(tmp.v);if(!vis[id]){vis[id] = 1;q.push(node(tmp.v, tmp.path + dir2[i]));}swap(tmp.v[tx * 3 + ty], tmp.v[sx * 3 + sy]);}}return "unsolvable";
}
int main()
{char input[2];while(~scanf("%s", input)){vector <int> v;if(input[0] == 'x')v.push_back(9);elsev.push_back(input[0] - '0');for(int i = 0; i < 8; i++){scanf("%s", input);if(input[0] == 'x')v.push_back(9);elsev.push_back(input[0] - '0');}int sum = 0;for(int i = 1; i < 9; i++)for(int j = 0; j < i; j++)if(v[i] != 9 && v[j] != 9 && v[i] < v[j]) sum++;if((sum & 1) == 0)cout << bfs(v) << endl;elseputs("unsolvable1");}return 0;
}

  

转载于:https://www.cnblogs.com/Apro/p/4807512.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/431369.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

成都软件工程师python_为什么每个软件工程师都应该学习Python?

为什么要写一篇文章告诉大家去学习python&#xff1f;最受欢迎的编程语言不是JAVA么&#xff1f;的确&#xff0c;TIOBE指数显示JAVA依然是最受欢迎的编程语言&#xff0c;但是Python的崛起不可小觑&#xff0c;请看4月份最新的TIOBE指数其实从2016年起&#xff0c;Python就已经…

linux修改某个用户的数组,linux-shell编程1:变量和数组

Shell用户与系统内核之间交流平台Shell类型/bin/sh/bin/bash(系统默认bash)/bin/tcsh/bin/csh/etc/shells 放置当前系统可用shell为什么需要shell编程1.减少繁琐工作的重复进行&#xff0c;减少错误2.提高工作效率3.事态的批量化进行Bash特点功能1.查看命令历史(1000条)history…

erlang OTP中的四大behaviour fsm的例子

下面是一个fsm的例子&#xff0c;代码如下&#xff1a; 1 -module(code_lock2).2 3 -behaviour(gen_fsm).4 -export([start_link/1]).5 -export([button/1]).6 -export([init/1, locked/2, open/2]).7 -export([code_change/4, handle_event/3, handle_info/3, handle_sync_eve…

node python复用代码_python-代码复用(函数、lambda、递归、PyInstaller库)

一、函数1、函数定义def 函数名(参数列表)&#xff1a;2、返回值 return返回值可以有多个&#xff0c;其实是返回一个tuple##多个返回值def sumDiff(x,y):return xy,x-yn1,n2 eval(input(输入两个数&#xff1a;))s,d sumDiff(n1,n2)print(和为{}&#xff0c;差为{}.format(…

关于linux内核的有关叙述中,下列关于嵌入式Linux系统内核的叙述正确的是()。

听力原文&#xff1a; A $150 million project to replace all of the vertical suspension cables on the 100-year-old Manhattan Bridge will cause occasional weekend disruptions in subway service and require closings of the bikeway and some traffic lanes for par…

WebStorm 预览时把浏览器地址localhost 改成IP

最近在使用WebStorm时&#xff0c;预览网页时地址总是显示的 http://localhost:63342/... &#xff0c;如果要调试其它设备感觉很不方法&#xff0c;此时肯定首先想到的亲爱的度娘&#xff0c;但是貌似没有真正很解决问题的&#xff08;可能是我搜索方法不对&#xff09;。最后…

通用即插即用监视器驱动下载_电脑设备驱动程序有问题,教你3招,快速修复...

驱动程序允许你的设备与Windows 10进行通信。计算机必须安装最新版本的驱动程序才能正常运行。设备驱动程序是一种特殊的软件程序&#xff0c;它控制连接到计算机的特定硬件设备&#xff0c;设备驱动程序对于计算机促进系统与所有已安装程序或应用程序之间的通信至关重要&#…

python在线投票系统讲解_在线投票系统功能分析

网上投票系统的功能一、功能概述(1)客户模块客户模块主要是添加投票项目信息&#xff0c;比如投票项目的题目&#xff0c;选项以及系统配置的要求。(2)新闻模块新闻模块主要是一些关于本系统的新闻信息&#xff0c;其中包括新闻显示和添加删除模块。(3)留言薄模块留言薄模块主要…

linux内存管理的主要概念是虚拟内存,你知道linux内存管理基础及方法?

描述一、基本概念(1)物理内存和虚拟内存物理内存&#xff1a;系统硬件提供的真实物理内存虚拟内存&#xff1a;利用磁盘空间虚拟出的一块逻辑内存&#xff0c;用作虚拟内存的磁盘空间被称为swap&#xff0c;swap类似于windows的虚拟内存。1、linux的内存管理采取的分页存取机制…

R plot图片背景设置为透明_R语言入门第十二讲:基础绘图(二)------plot与par函数(1)...

上一次给大家简单展示了plot函数的用法&#xff0c;以及par函数的使用。今天我们继续应用这两个函数&#xff0c;看看它的其他功能。下面这个图是数据的一部分[1]。我一直认为&#xff0c;作图简单&#xff0c;但关键是要知道数据在数据库中的格式&#xff0c;才能更好的应用到…

qqkey获取原理_【逆向】QQkey盗号木马原理分析

一、简介QQkey是一段字符串&#xff0c;通过这段字符串在没有QQ登录密码的前提下你依然能够在浏览器中对别人QQ空间、邮箱等应用进行随意访问和操作。现在市面上已经有很多使用易语言编写的盗号木马&#xff0c;专门盗取别人的QQkey&#xff0c;通过QQkey改绑关联了该邮箱的Ste…

visual studio 2015 搭建python开发环境,python入门到精通[三]

在上一篇博客Windows搭建python开发环境&#xff0c;python入门到精通[一]很多园友提到希望使用visual studio 2013/visual studio 2015 python做demo&#xff0c;这里略带一句&#xff0c;其实就"学习python"而言&#xff0c;比较建议使用pycharm&#xff0c;pychar…

linux 用脚本建分区,脚本创建磁盘分区

首先最好添加一个空白的磁盘&#xff0c;以免对原数据产生破坏&#xff0c;若果不想添加磁盘也可以&#xff0c;用一个里面数据无关紧要的磁盘&#xff0c;当然前提是必须要对该磁盘内已有的分区进行清空&#xff0c;方法后面第三步会有1.先看脚本内容&#xff1a;[rootlocalho…

如何给打印机墨盒加墨

今天打印东西突然遇到问题了&#xff0c;显示墨盒黑色没墨了&#xff0c;网上一搜&#xff0c;整套的墨盒大几十&#xff0c;随手换了一个关键词 墨盒墨水 这下不到十块钱解决&#xff0c;正好锻炼下自己的动手能力&#xff08;其实就是穷嘛。。。&#xff09; 接下来就分享下动…

三轴加速度传感器和六轴惯性传感器_六轴传感器和三轴传感器的区别

六轴传感器和三轴传感器的区别重力重力传感器就是利用了其内部的由于加速度造成的晶体变形这个特性。由于这个变形会产生电压&#xff0c;只要计算出产生电压和所施加的加速度之间的关系&#xff0c;就可以将加速度转化成电压输出。当然&#xff0c;还有很多其它方法来制作加速…

全局莫兰指数_空间自相关 | 莫兰指数

空间自相关&#xff1a;是指一些变量在同一个分布区内的观测数据之间潜在的相互依赖性。其中&#xff0c;自相关中的“自”表示当你进行相关性观察统计量&#xff0c;是来源于不同对象的同一属性。Tobler(1970)曾指出“地理学第一定律&#xff1a;任何东西与别的东西之间都是相…

宏函数和函数的区别

转载自&#xff1a; http://www.ccidnet.com/2010/0709/2110463.shtml 1. 宏做的是简单的字符串替换(注意是字符串的替换,不是其他类型参数的替换),而函数的参数的传递,参数是有数据类型的,可以是各种各样的类型. 2. 宏的参数替换是不经计算而直接处理的,而函数调用是将实参的值…

linux vi 排序命令,10 个你必须掌握的超酷 VI 命令技巧

摘要&#xff1a;大部分Linux开发者对vi命相当熟悉&#xff0c;可是遗憾的是&#xff0c;大部分开发者都只能掌握一些最常用的Linux vi命令&#xff0c;下面介绍的10个vi命令虽然很多不为人知&#xff0c;但是在实际应用中又能让你大大提高效率。在使用vi 编辑器时—无论是初次…

python微信机器人部署服务器_玩法收藏/云服务器/零基础微信机器人实践( Python )...

最近想做个微信机器人&#xff0c;主要是为了个人方便。在腾云阁发现这个教程&#xff0c;得到了一些启发。(修改转载已取得腾讯云授权)技术路径和实现思路首先编程语言使用了 Python &#xff0c; Python 语法简洁、第三方扩展丰富&#xff0c;也因为这里采用的微信消息框架 i…

arduino 水位传感器_云南可信赖的威卡压力传感器哪里有

云南可信赖的威卡压力传感器哪里有 k52gh264云南可信赖的威卡压力传感器哪里有 在生产生活中&#xff0c;对压力表的正确使用为工业生产提供了一定程度的便利。.指针转动受阻在检修过程中&#xff0c;先给弹賛管式压力表施加压力&#xff0c;如果发现被检测表的指针成比例变快或…