今天组队赛的一道最短路的题,给你一个矩阵,矩阵上有L,R,G,A,分别表示当你到达这个点的时候你要向左,向右,向前,向后走,如果要向别的方向走需要花费1点的魔力,正常情况下走需要花费1点的时间。问花费最小魔力的时候的最少时间是多少。 一个机智的处理方法是向别的方向走的时候的花费1*100000000,然后构图跑最短路出来的结果/100000000就是最小的魔力,%100000000就是最小的时间。

但是比赛的时候WA了好久,赛后RE了好久。终于发现一个严重的问题----队列开小了。

平时最短路都是STL里的队列,这次用了手写的队列,然后手写的队列又没有弄成循环的队列,所以就跪了。写下来警醒自己:

手写队列要小心!!!!!

手写队列要小心!!!!!

手写队列要小心!!!!!

#pragma warning(disable:4996)
#include <iostream>
#include <cstring>
#include <string>
#include <vector>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <queue>
#include <map>
#include <ctime>
using namespace std; #define maxn 120
#define ll long long
int n, m; int dx[4] = { 0, 1, 0, -1 };
int dy[4] = { 1, 0, -1, 0 }; const ll hcost = 100000000; int cd(int k, char cmd){
if (cmd == 'G') return k;
else if (cmd == 'L') return (k + 3) % 4;
else if (cmd == 'R') return (k + 1) % 4;
else return (k + 2) % 4;
} char b[maxn][maxn]; struct Edge{
int v; ll w;
Edge(int vi, ll wi) :v(vi), w(wi){}
Edge(){}
};
vector<Edge> G[maxn*maxn * 8]; int getid(int i, int j, int k){
return 4 * (i*m + j) + k;
} bool in[maxn*maxn * 8];
ll d[maxn*maxn * 8];
bool vis[maxn*maxn * 8]; void spfa()
{
memset(in, 0, sizeof(in));
memset(d, 0x3f, sizeof(d));
memset(vis, 0, sizeof(vis));
in[0] = true; d[0] = 0;
queue<int> que;
que.push(0);
while (!que.empty()){
int u = que.front(); in[u] = false; que.pop();
for (int i = 0; i < G[u].size(); ++i){
int v = G[u][i].v;
ll w = G[u][i].w;
if (d[u] + w < d[v]){
d[v] = d[u] + w;
if (!in[v]) {
que.push(v);
in[v] = true;
}
}
}
}
} int main()
{
//freopen("C.in", "r", stdin);
//freopen("out.txt", "w", stdout);
//double t1 = clock();
while (cin >> n >> m){
for (int i = 0; i < n; ++i){
scanf("%s", b[i]);
}
for (int i = 0; i <= n*m * 6; ++i){
G[i].clear();
}
for (int i = 0; i < n; ++i){
for (int j = 0; j < m; ++j){
for (int k = 0; k < 4; ++k){
int id = getid(i, j, k);
char cmd = b[i][j];
int cord = cd(k, cmd);
int xx, yy;
for (int kk = 0; kk < 4; ++kk){
xx = i + dx[kk]; yy = j + dy[kk];
if (!(xx >= 0 && xx < n&&yy >= 0 && yy < m)) continue;
if (kk == cord) {
G[id].push_back(Edge(getid(xx, yy, kk), 1LL));
}
else{
G[id].push_back(Edge(getid(xx, yy, kk), hcost + 1));
}
}
}
}
}
spfa();
ll ans = 1e15;
for (int i = 0; i < 4; ++i){
int idd = getid(n - 1, m - 1, i);
ans = min(ans, d[idd]);
}
printf("%lld %lld\n", ans / hcost, ans%hcost);
}
//double t2 = clock();
//cout << t2 - t1 << endl;
return 0;
}

NSOJ 鬼泣的更多相关文章

  1. NSOJ A fairy tale of the two(最小费用最大流、SPFA版本、ZKW版本)

    n,m<=20,给两个n×m布尔矩阵,每次操作可将第一个矩阵的2个相邻元素互换.输出最少操作次数使得两个矩阵完全一样. 比赛的时候想过按照二分图完美匹配的类似做法构图,不过想到边太多以及卡各种题 ...

  2. NSOJ 飞船汇合(经典)

    一支分散的飞船舰队,需要汇合到主舰,但是这种飞船在太空中飞行的耗油与质量没有关系,只与发动机打开的时间有关系,为了节省油量,指挥官通知,汇合途中,多台飞船可以串成串飞行,这样只需启动一台发动机,由于安 ...

  3. NSOJ Minimum Transport Cost

    These are N cities in Spring country. Between each pair of cities there may be one transportation tr ...

  4. NSOJ 一个人的旅行(图论)

    虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰富自己的阅历,还可以看美丽的风景……草儿 ...

  5. NSOJ Constructing Roads(图论)

    There are N villages, which are numbered from 1 to N, and you should build some roads such that ever ...

  6. NSOJ 畅通工程(并查集)

    某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府“畅通工程”的目标是使全省任何两个城镇间都可以实现交通(但不一定有直接的道路相连,只要互相间接通过道路可达即可). ...

  7. NSOJ 4621 posters (离散化+线段树)

    posters 时间限制: 1000ms 内存限制: 128000KB 64位整型:      Java 类名: 上一题 提交 运行结果 统计 讨论版 下一题 题目描述 The citizens of ...

  8. DEVIL MAY CRY V:《鬼泣5》

    “又是一个带孝子的故事”

  9. VR原理讲解及开发入门

    本文是作者obuil根据多年心得专门为想要入门的VR开发者所写,由52VR网站提供支持.   1. VR沉浸感和交互作用产生的原理:   在之前,我们观看一个虚拟的创造内容是通过平面显示器的,52VR ...

随机推荐

  1. perl thread

    #!/usr/local/bin/perl use threads; @domain = ("tom.com", "chinadns.com", "1 ...

  2. sublime text 3 设置

    最近开始用sublime text 3,查资料总结了一下常用的设置,记录下以备用,同时也希望能改大家带来方便 0.使用package control安装,点前边超链接,复制左侧代码到console,回 ...

  3. EMVTag系列14《支付环境响应数据》

    1. 选择PSE支付环境响应数据 标签 长度 数据域 存在性 9102 A5 变长 FCI数据专用模板 强制 88 1 目录基本文件的SFI 强制 5F2D 2 首选语言 可选 9F11 1 发卡行代 ...

  4. Datastage数据装载报错:Consumed more than 1000000 bytes looking for record delimiter

    使用Datastage装载数据时报错如下图: 使用ds进行数据传输时,出现上述问题,最终找到了问题的原因: 我所使用的数据文件比较大,上传到服务器的时候传了80%就出现服务器存储空间不够,我删除以前的 ...

  5. 使用Linux调用资源库中的Job报错-ERROR: No repository provided, can't load job.

    使用kettle调用资源库中的作业或者是转换,需要注意一下两个问题: 问题一:(-rep后不需要IP)标准shell代码如下 #!/bin/bash export JAVA_HOME=/usr/lib ...

  6. Linux编译内核提示'make menuconfig' requires the ncurses libraries错误

    原来使用的ubuntu 11.10系统由于误操作,导致系统崩溃,重新安装了ubuntu 11.10: 在编译内核的时候,提示如下错误: dingq@wd-u1110:~/hwsvn/2sw/1prj_ ...

  7. struts2传递参数值的3中方式

    在使用struts2的时候,当要传递的参数不多的时候,我们会选择使用属性来传参,而当要传递的参数很多的时候,或者多个action会有共用的参数时,我们会使用另外两种传参方式. 注意:使用Model D ...

  8. andirod

    于adnroid老手来说,SDK环境搭建是很简单的,但是对于我这样的小白来说,,,,,走啦很多弯路..特记下.希望对兄弟们有所帮助 因为我也是参考网上的高手知道,所以有的就直接复制啦,,^_^ 想要开 ...

  9. iOS学习之UIView

    一.UI编程概述      1.UI的本意是用户界面,是英文User和Interface的缩写.      2.UI设计则是指对软件的人机交互.操作逻辑.界面美观的整体设计.      3.软件设计可 ...

  10. typings的理解

    简介一些js库扩展了JavaScript的特性和语法,但是TypeScript编译器并不识别,通过typings.json配置可以辅助IDE,给出有智能的提示信息,以及重构的依据.因此需要在typin ...