1445 变色DNA
基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题
有一只特别的狼,它在每个夜晚会进行变色,研究发现它可以变成N种颜色之一,将这些颜色标号为0,1,2…N-1。研究发现这只狼的基因中存在一个变色矩阵,记为colormap,如果colormap[i][j]=’Y’则这只狼可以在某一个夜晚从颜色i变成颜色j(一晚不可以变色多次),如果colormap[i][j]=‘N’则不能在一个晚上从i变成j色。进一步研究发现,这只狼每次变色并不是随机变的,它有一定策略,在每个夜晚,如果它没法改变它的颜色,那么它就不变色,如果存在可改变的颜色,那它变为标号尽可能小的颜色(可以变色时它一定变色,哪怕变完后颜色标号比现在的大)。现在这只狼是颜色0,你想让其变为颜色N-1,你有一项技术可以改变狼的一些基因,具体说你可以花费1的代价,将狼的变色矩阵中的某一个colormap[i][j]=’Y’改变成colormap[i][j]=’N’。问至少花费多少总代价改变狼的基因,让狼按它的变色策略可以从颜色0经过若干天的变色变成颜色N-1。如果一定不能变成N-1,则输出-1.
Input
多组测试数据,第一行一个整数T,表示测试数据数量,1<=T<=5
每组测试数据有相同的结构构成:
每组数据第一行一个整数N,2<=N<=50。
之后有N行,每行N个字符,表示狼的变色矩阵,矩阵中只有‘Y’与‘N’两种字符,第i行第j列的字符就是colormap[i][j]。
Output
每组数据一行输出,即最小代价,无解时输出-1。
Input示例
3
3
NYN
YNY
NNN
8
NNNNNNNY
NNNNYYYY
YNNNNYYN
NNNNNYYY
YYYNNNNN
YNYNYNYN
NYNYNYNY
YYYYYYYN
6
NYYYYN
YNYYYN
YYNYYN
YYYNYN
YYYYNN
YYYYYN
Output示例
1
0
-1

这题很暴力,不过要想通的一点是,cost[i][j] = 第i行j之前出现的‘Y’的数量。
然后求单源最短路径即可,注意:求出为INF即为不可达,输出-1。

Bellman-Ford算法详解:http://www.cnblogs.com/zhangjiuding/p/7712435.html

代码:

#include <iostream>
#include <algorithm>
#include <map>
#include <vector>
using namespace std;
typedef long long ll;
#define INF 2147483647struct edge{int from,to,cost;
};int t,n,E; edge es[2510];
int d[55];char color[55][55];//Bellman-Ford算法求单源最短路径
void shortest_path(int s){fill(d,d+n,INF);d[s] = 0;while(true){bool update = false;for(int i = 0;i < E; i++){edge e = es[i];if(d[e.from] != INF && d[e.to] > d[e.from] + e.cost){d[e.to] = d[e.from] + e.cost;update = true;}}if(!update) break;}
}int main(){cin >> t;while(t--){cin >> n;int f = 0;E = 0;for(int i = 0;i < n; i++){int cost = 0;for(int j = 0;j < n; j++){cin >> color[i][j];if(color[i][j] == 'Y'){es[E].from = i;es[E].to = j;es[E].cost = cost;cost++; E++;}}if(color[i][n-1] == 'Y') f = 1;}shortest_path(0);if(d[n-1] != INF)cout << d[n-1] <<endl;else cout << -1 << endl;}return 0;
} 

51nod 1445 变色DNA ( Bellman-Ford算法求单源最短路径)相关推荐

  1. Dijkstra(迪杰斯特拉)算法求单源最短路径问题

    Dijkstra(迪杰斯特拉)算法求单源最短路径问题 重要的事情说三遍:代码不是我写的!代码不是我写的!代码不是我写的! 第一个算法是严蔚敏数据结构(C语言版)上写的,第二个算法是王道数据结构上写的, ...

  2. 【2023王道数据结构】【图】通过C++实现图的BFS(广度优先遍历)算法求单源最短路径问题C、C++完整实现(可直接运行)

    ~~~笔锋至此又怎能平淡而终,故事开始便不承认普通✌✌✌ ✌ 题目及题解持续更新中 [2023王道数据结构目录]课后算法设计题C.C++代码实现完整版大全 题目: 通过C++实现图的BFS(广度优先遍 ...

  3. Dijkstra算法求单源最短路径

    1.最短路径 在一个连通图中,从一个顶点到另一个顶点间可能存在多条路径,而每条路径的边数并不一定相同.如果是一个带权图,那么路径长度为路径上各边的权值的总和.两个顶点间路径长度最短的那条路径称为两个顶 ...

  4. AOJ GRL_1_A: Single Source Shortest Path (Dijktra算法求单源最短路径,邻接表)

    题目链接:http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=GRL_1_A Single Source Shortest Path In ...

  5. AOJ GRL_1_A: Single Source Shortest Path (Dijktra算法求单源最短路径,邻接表)

    题目链接:http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=GRL_1_A Single Source Shortest Path In ...

  6. C语言基本数据结构之三(图的广度及深度遍历,求单源最短路径的Dijkstra算法)

    上一篇主要讲了二叉树的先序,中序,后序遍历算法以及深度和节点的算法,这篇就讲一讲图的基本算法. 一.图的基本概念 1.1有向图G1: 有向图G是由两个集合V(G)和E(G)组成的,其中:V(G)是顶点 ...

  7. matlab结束外循环,求单源最短路径的BellmanFord算法的matlab实现及其优化

    function [minD,path] = BellmanFord(w,start,terminal) %求单源最短路径的Bellman-Ford算法(图论) %调用格式:[minD,path] = ...

  8. 最短路径:Dijkstra算法(求单源最短路径)Floyd算法(求各顶点之间最短路径)

    最短路径: 在一个带权图中,顶点V0到图中任意一个顶点Vi的一条路径所经过边上的权值之和,定义为该路径的带权路径长度,把带权路径最短的那条路径称为最短路径. DiskStra算法: 求单源最短路径,即 ...

  9. 图的最短路径之Dijkstra求单源最短路径算法(C++)

    一个有向带权图求它的单源最短路径可以使用Dijkstra算法. 单源最短路径是指:从图中的某个顶点出发,到其余各个顶点权值最小的路径. Dijkstra算法需要用到三个辅助数组: dist[max]: ...

最新文章

  1. tp5获取mysql版本_TP5 + MySQL 应用地址选择
  2. Oracle之数据库设计概述
  3. 关闭浏览器 清空session_跨境网络小知识之Session
  4. React开发(119):代码原因
  5. HbuilderX、Hbuilder编辑器如何使用手机调试app
  6. cross validation交叉验证
  7. html怎样自动播放视频,html5如何实现自动播放视频?
  8. 灭顶之灾之网络电视精灵——S2 2.8
  9. window.location.href跳转无效 IE Bug【转载】
  10. C++基础——类模板
  11. docker elasticsearch安装
  12. OPPO R17忘记用户账户密码强制清除登录账号
  13. 网络编程-UDP编程
  14. 社交媒体用户行为研究,图神经网络 社交网络
  15. java定时器 实现2秒打印一次,1秒打印一次,循环往复
  16. python对数据进行分组怎么实现_Python--DataFrame分组-GroupBy
  17. SpringBoot-SSMP超详细整合案例
  18. 决策树案例学习(Python实现)
  19. 如何避免扫码枪重复扫码
  20. 自己用c语言做的日历

热门文章

  1. 如何确定电脑主板坏了_【不良资产 】(第1422期)银行在打包不良资产出售之前,会如何处置不良资产?...
  2. Java黑皮书课后题第6章:*6.2(求一个整数各位数字之和)编写一个方法,计算一个整数各位数字之和。使用下面的方法头:public static int sumDigits(long n)
  3. Java黑皮书课后题第3章:**3.22(几何:点是否在圆内)编写程序,提示用户输入一个点(x,y),然后检查这个点是否在以(0,0)为圆心、半径为10的圆内
  4. Java黑皮书课后题第3章:*3.5(给出将来的日期)编写一个程序,提示用户输入代表今天日期的数字(周日0周一1周二2)同时用户输入一个今天之后的天数代表将来某天的数字,然后显示这天是周几
  5. 后缀数组求最长重复子串
  6. 解决vscode安装后无法启动的问题
  7. Pro Android学习笔记(二九):用户界面和控制(17):include和merge
  8. [Python图像处理] 七.图像阈值化处理及算法对比
  9. RxSwift之UI控件UITableView扩展的使用
  10. iOS之深入解析预乘透明度Premultiplied Alpha