hdu1572 水搜索
题意:
中文的不解释;
思路:
其实就是一个水的搜索,直接搜索不会超时,还有别跑最短路了,题目没要求跑最短路,别读错题,刚开始自己嘚嗖的跑了一边最短路 wa了 ,正好最近看了STL的全排列就写下吧,省着忘了,反正没有剪枝的深搜也是全排列的枚举..
#include<stdio.h>
#include<algorithm>
#define N 30 + 5
#define inf 1000000000
using namespace std;
int main ()
{
int map[N][N];
int num[10];
int i ,j ,k ,n ,nn ,ans;
while(scanf("%d" ,&n) && n)
{
for(i = 1 ;i <= n ;i ++)
for(j = 1 ;j <= n ;j ++)
{
scanf("%d" ,&map[i][j]);
}
scanf("%d" ,&nn);
for(i = 1 ;i <= nn ;i ++)
{
scanf("%d" ,&num[i]);
num[i] ++;
}
int c = 1;
for(i = 1 ;i <= nn ;i ++)
c *= i;
ans = inf;
int temp = map[1][num[1]];
for(i = 2 ;i <= nn ;i ++)
temp += map[num[i - 1]][num[i]];
if(ans > temp)
ans = temp;
while(--c)
{
next_permutation(num + 1 ,num + nn + 1);
temp = map[1][num[1]];
for(i = 2 ;i <= nn ;i ++)
temp += map[num[i - 1]][num[i]];
if(ans > temp)
ans = temp;
}
printf("%d\n" ,ans);
}
return 0;
}
最新文章
- [redis] Node is not empty. Either the node already knows other nodes
- IOS学习笔记 O1
- libevent
- Android -- 桌面悬浮,仿360
- C#之你懂得的反射
- Unix环境高级编程
- [Redux] React Todo List Example (Toggling a Todo)
- Hex Workshop(16进制编辑利器) 6.7.2绿色版
- Design Pattern - Strategy
- fedora安装QQ
- 【LeetCode】数组-2(628)-数组中三个数相乘最大
- JavaScript之Promise对象
- django2.0无法加载外部css和js的问题
- SpringBoot史前简述
- c#命名规范(转载)
- IPv6下网络编程socket, TCP和UDP例子,以及兼容IPV4和IPV6的类
- 【微收藏】FourShadows.js – 时间感知的算法驱动的图标阴影JS库
- text2
- 那些年读过的书《Java并发编程的艺术》一、并发编程的挑战和并发机制的底层实现原理
- IIS站点工作原理与ASP.NET工作原理