poj3013 邻接表+优先队列+Dij
把我坑到死的题
开始开题以为是全图连通是的最小值 ,以为是最小生成树,然后敲了发现不是,看了下别人的题意,然后懂了;
然后发现数据大,要用邻接表就去学了一下邻接表,然后又去学了下优先队列优化的dij;
这坑爹的题目我交了10几遍,也不知道错在哪里;后来知道了maxint要#define Maxint 10000000000;
然后long int 是过不了的,改成long long才能过 ,真是呵呵啊;
#include<stdio.h>
#include<string.h>
#include<queue>
using namespace std;
#define Maxint 10000000000 struct node
{
long long v;//后面点
long long w;//权
long long next;//记录同一起点的下一条边的位置
}edge[]; long long n,m,index,nodeval[],dis[],vis[]; long long pre[];//开始的顶点 void add(long long x,long long y,long long z)
{
edge[index].v=y;
edge[index].w=z;
edge[index].next=pre[x];
pre[x]=index++; /*edge[index].v=x;
edge[index].w=z;
edge[index].next=pre[y];
pre[y]=index++;*/ } struct Node
{
long long point,dist;
bool operator<(const Node x) const
{
return x.dist<dist;
}
}; void dij(int s)
{
priority_queue<Node> q;
long long i,j;
for(i=;i<=n;i++)
{
dis[i]=Maxint;
}
dis[]=;
Node cur;
cur.point=;
cur.dist=;
q.push(cur);
while(!q.empty())
{
Node tmp;
tmp=q.top();
q.pop();
long int u=tmp.point;
if(vis[u])
continue;
vis[u]=;
for(j=pre[u];j!=-;j=edge[j].next)
{
if(!vis[edge[j].v]&&dis[edge[j].v]>dis[u]+edge[j].w)
{
dis[edge[j].v]=dis[u]+edge[j].w;
cur.dist=dis[edge[j].v];
cur.point=edge[j].v;
q.push(cur);
}
}
}
} int main()
{
int i,j,t;
scanf("%d",&t);
while(t--)
{
scanf("%lld %lld",&n,&m);
for(i=;i<=n;i++)
scanf("%ld",&nodeval[i]);
index=;
memset(vis,,sizeof(vis));
memset(pre,-,sizeof(pre));
for(i=;i<m;i++)
{
long long x,y,z;
scanf("%lld %lld %lld",&x,&y,&z);
if(x==y)continue;
add(x,y,z);
add(y,x,z);
}
dij();
long long ans=,flag=;
for(i=;i<=n;i++)
{
if(dis[i]==Maxint)
{
flag=;break;
}
ans+=(dis[i]*nodeval[i]);
}
if(flag)printf("No Answer\n");
else printf("%lld\n",ans);
}
}
poj3013 邻接表+优先队列+Dij的更多相关文章
- HDU 1535 Invitation Cards(逆向思维+邻接表+优先队列的Dijkstra算法)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1535 Problem Description In the age of television, n ...
- NBOJv2——Problem 1037: Wormhole(map邻接表+优先队列SPFA)
Problem 1037: Wormhole Time Limits: 5000 MS Memory Limits: 200000 KB 64-bit interger IO format: ...
- Prime邻接表+优先队列
#include <iostream> #include <cmath> #include <cstring> #include <cstdlib> # ...
- Genealogical tree(拓扑结构+邻接表+优先队列)
Genealogical tree Time Limit : 2000/1000ms (Java/Other) Memory Limit : 131072/65536K (Java/Other) ...
- HDU 2544 最短路(邻接表+优先队列+dijstra优化模版)
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- 基于STL优先队列和邻接表的dijkstra算法
首先说下STL优先队列的局限性,那就是只提供入队.出队.取得队首元素的值的功能,而dijkstra算法的堆优化需要能够随机访问队列中某个节点(来更新源点节点的最短距离). 看似可以用vector配合m ...
- 06-图1 列出连通集 (25分)(C语言邻接表实现)
题目地址:https://pta.patest.cn/pta/test/558/exam/4/question/9495 由于边数E<(n*(n-1))/2 所以我选用了邻接表实现,优先队列用循 ...
- SDUT2142数据结构实验之图论二:基于邻接表的广度优先搜索遍历
http://acm.sdut.edu.cn/sdutoj/showproblem.php?pid=2142&cid=1186 题目描述 给定一个无向连通图,顶点编号从0到n-1,用广度优先搜 ...
- Invitation Cards(邻接表+逆向建图+SPFA)
Time Limit: 8000MS Memory Limit: 262144K Total Submissions: 17538 Accepted: 5721 Description In ...
随机推荐
- TC(Total Commander)文件管理神器
TC文件管理神器 Total Commander是一个会显著提高文件操作效率的工具,而文件操作是应用计算机最基本的功夫,也是伴随一生的操作.因此花一点时间学习,而会受益一世. Total Comman ...
- NOIP2003 神经网络
题目背景 人工神经网络(Artificial Neural Network)是一种新兴的具有自我学习能力的计算系统,在模式识别.函数逼近及贷款风险评估等诸多领域有广泛的应用.对神经网络的研究一直是当今 ...
- UITableViewCell 多选和全选(checkBoxCell)
思路1 一.全选 1.创建可变数组,存储所有未选中状态(NO)的布尔值按钮,点击时改变其状态,并传入按钮的状态. 二.多选 1.创建Cell时,从数组中取出相应的值,传给cell,如果为YES,否则为 ...
- HTML 学习笔记 JavaScript(数据类型)
字符串 数字 布尔 数组 对象 Null Undefined JavaScript 拥有动态类型 JavaScript拥有动态类型 这意味着相同的变量可用作不同的类型: 实例: var x // x ...
- .Net Core 控制台程序错误:Can not find runtime target for framework '.NETCoreApp,Version=v1.0' compatible with one of the target runtimes: 'win10-x64, win81-x64, win8-x64, win7-x64'.
.Net Core 控制台程序错误:Can not find runtime target for framework '.NETCoreApp,Version=v1.0' compatible wi ...
- python读取配置文件
从/mnt目录下读取section配置文件sample.ini [db] host=192.168.1.116 hostaddr=192.168.1.116 port=5432 dbname=clas ...
- usb驱动开发16之设备生命线
回到struct usb_hcd,继续努力的往下看. kref,usb主机控制器的引用计数.struct usb_hcd也有自己专用的引用计数函数,看hcd.c文件. static void hcd_ ...
- 利用javascript对提交数据验证
优点:提交前验证.在客户端进行. <html> <head> <script language="javascript"> function c ...
- 写Java也得了解CPU--CPU缓存
CPU,一般认为写C/C++的才需要了解,写高级语言的(Java/C#/pathon...)并不需要了解那么底层的东西.我一开始也是这么想的,但直到碰到LMAX的Disruptor,以及马丁的博文,才 ...
- 安装mint的时候提示:Not compatible with your operating system or architecture: fsevents@1.0.11
Since fsevents is an API in OS X allows applications to register for notifications of changes to a g ...