题解 guP3956 棋盘
好吧本来这题可以用最短路跑完的,结果我硬是打了1.5小时的dfs。。。
其实这题并没有那么难,构造一个无向图再跑最短路即可。
我用的dj跑最短路
问题来了
如果(n,n)是无色的,那么图上就没有这个点
可以构造一个变量flag记录点(n,n)是否有颜色
若flag==0,则在地图上新加一个点。
点与点间的路程情况:
- 相邻且颜色相同,z[i][j]=0; 
- 相邻且颜色不同,z[i][j]=1; 
- 相隔一格且颜色相同,z[i][j]=2; 
- 相隔一格且颜色不同,z[i][j]=3; 
∴点i与点j的距离=其颜色差的绝对值+位置差(是否使用膜法)
即
		if(abs(x[i]-x[j])+abs(y[i]-y[j])==1)
		{
			z[i][j]=z[j][i]=abs(col[i]-col[j]);
		}
		if(abs(x[i]-x[j])+abs(y[i]-y[j])==2)
		z[i][j]=z[j][i]=2+abs(col[i]-col[j]);
献上代码:
#include<bits/stdc++.h>
using namespace std;
bool f[1002];
int n,m,x[1002],y[1002],z[1002][1002],col[1002],sta,en,flag,s[1002];
void dj(int k)
{
	s[k]=0;
	int maxn,t;
	for(int i=1;i<=m;i++)
	{
    	maxn=99999999;
    	for(int j=1;j<=m;j++)
    	{
        	if(f[j]==0&&s[j]<maxn)
       		{
            	maxn=s[j];
				t=j;
        	}
    	}
    	f[t]=1;
    	for(int j=1;j<=m;j++)
		{
			s[j]=min(s[t]+z[t][j],s[j]);
		}
	}
}
int main()
{
  	//freopen("chess.in","r",stdin);
  	//freopen("chess.out","w",stdout);
  	memset(z,1,sizeof(z));
  	memset(s,1,sizeof(s));
	scanf("%d%d",&n,&m);
	for(int i=1;i<=m;i++)
	{
		scanf("%d%d%d",&x[i],&y[i],&col[i]);
		if(x[i]==1&&y[i]==1)
		{
			sta=i;
		}
		if(x[i]==n&&y[i]==n)
		{
			flag=1;
			en=i;
		}
	}
	if(flag==0)
	{
		en=m+1;
		x[en]=y[en]=n;
	}
	for(int i=1;i<m;i++)
	{
		for(int j=i+1;j<=m;j++)
		{
			if(abs(x[i]-x[j])+abs(y[i]-y[j])==1)
			{
				z[i][j]=z[j][i]=abs(col[i]-col[j]);
			}
			if(abs(x[i]-x[j])+abs(y[i]-y[j])==2)
			z[i][j]=z[j][i]=2+abs(col[i]-col[j]);
		}
	}
	if(flag==0)
	{
		for(int i=1;i<=m;i++)
		{
			if(abs(x[i]-x[en])+abs(y[i]-y[en])==1)
			{
				z[i][en]=z[en][i]=2;
			}
		}
		m++;
	}
	dj(sta);
	if(s[en]<16843009)
	cout<<s[en];
	else
	cout<<-1;
	return 0;
}
题解 guP3956 棋盘的更多相关文章
- [洛谷P1169][题解][ZJOI2007]棋盘制作
		我不是题目的说 这道题运用了一种很巧妙的DP方式:悬线法 如图,蓝色为悬线,黄色为向两边延伸的长度 那么显然,最大子矩形的宽一定是这些黄线中最小的(证明从略) 所以我们可以维护三个数组: Up[i][ ... 
- 【NOIP2013】华容道(最短路)
		题目戳我 懒得粘贴题目了..就这要凑合一下吧... 题解 反正棋盘的状态不会变的... 所以,预处理一下??? 恩,如果一个棋子要移动到某个目标位置的话, 可以看成只有空格和这个子要动呀(其他的有区别 ... 
- AtCoder Beginner Contest 183  E - Queen on Grid   (DP)
		题意:有一个\(n\)x\(m\)的棋盘,你需要从\((1,1)\)走到\((n,m)\),每次可以向右,右下,下走任意个单位,\(.\)表示可以走,#表示一堵墙,不能通过,问从\((1,1)\)走\ ... 
- luogu P1549 棋盘问题(2) 题解
		luogu P1549 棋盘问题(2) 题解 题目描述 在\(N * N\)的棋盘上\((1≤N≤10)\),填入\(1,2,-,N^2\)共\(N^2\)个数,使得任意两个相邻的数之和为素数. 例如 ... 
- BZOJ1057:[ZJOI2007]棋盘制作——题解
		http://www.lydsy.com/JudgeOnline/problem.php?id=1057 https://www.luogu.org/problemnew/show/P1169 国际象 ... 
- 小Y的棋盘问题 题解
		有一个n*m的棋盘,上面有一些棋子,每行每列最多只会有一个棋子,不会有两个棋子八连通.问随机一个空格子作为起点,再随机地选择一个空格子作为终点,求问不经过任意棋子最短路的期望长度是多少.多组,n,m& ... 
- 题解 P1436 【棋盘分割】
		题目链接 其实呢大致思路和下面的大佬们都很像.发这篇题解的目的就是加了一点~~优化~~骗分技巧. 转移方程: 设$dp[i][j][x][y][k]$表示左上$(i,j)$,右下$(x,y)$,第$k ... 
- 题解报告:poj 1321 棋盘问题(dfs)
		Description 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子 ... 
- POJ 1321 棋盘问题 题解
		棋盘问题 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 70224 Accepted: 33254 Description 在一 ... 
随机推荐
- 本地软件仓库配置及NFS安装
			[root@localhost ~]# mount /dev/cdrom /mnt mount: /dev/sr0 is write-protected, mounting read-only [ro ... 
- Go string 详解
			前言 字符串(string) 作为 go 语言的基本数据类型,在开发中必不可少,我们务必深入学习一下,做到一清二楚. 本文假设读者已经知道切片(slice)的使用,如不了解,可阅读 Go 切片 基本知 ... 
- 降维-基于RDD的API
			降维-基于RDD的API Singular value decomposition (SVD) Performance SVD Example Principal component analysis ... 
- GraphX编程指南
			GraphX编程指南 概述 入门 属性图 属性图示例 图算子 算子摘要列表 属性算子 结构化算子 Join算子 最近邻聚集 汇总消息(aggregateMessages) Map Reduce三元 ... 
- 毫米波RADAR与LIDAR探秘
			毫米波RADAR与LIDAR探秘 说起激光雷达和毫米波雷达,相信业内人士并不陌生,激光雷达是以发射激光束探测目标的位置.速度等特征量的雷达系统.而毫米波雷达是指工作在毫米波波段探测的雷达.毫米波实质上 ... 
- 并发王者课-铂金1:探本溯源-为何说Lock接口是Java中锁的基础
			欢迎来到<并发王者课>,本文是该系列文章中的第14篇. 在黄金系列中,我们介绍了并发中一些问题,比如死锁.活锁.线程饥饿等问题.在并发编程中,这些问题无疑都是需要解决的.所以,在铂金系列文 ... 
- 十二、iptables基本管理
			关闭firewalld,启动iptables服务 [root@proxy ~]# systemctl stop firewalld.service //关闭firewalld服务器 [root ... 
- Spring Cloud 和 Dubbo,到底用哪个好?
			Spring Cloud是http协议传输,带宽会比较多,同时使用http协议一般会使用JSON报文,消耗会更大 dubbo的开发难度较大,原因是dubbo的jar包依赖问题很多大型工程无法解决 sp ... 
- 【图论】用线段树写Dijikstra!!
			速度是没有极限的. 众说周知,Dijikstra是一种最短路算法,复杂度为O(V^2+E) 朴素Dijikstra void Dijikstra(int s){ memset(dis,inf,size ... 
- Linux命令大全之挂载命令
			理解:Linux挂载相当于Windows分配盘符 1.查询系统中已挂载的设备 mount 2.设置自动挂载 编辑文件/etc/fstab,把文件写入就可以启动自动挂载了, 注:一般不把光盘写入,如果写 ... 
