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 ...
随机推荐
- NOIP2005过河[DP 状态压缩]
题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数 ...
- 编辑器插件数据保存之Serializable
Editor数据保存需求 做编辑器插件开发时,当打开一个窗口,对数值进行修改后,在关闭窗口或重新打开Unity时,希望能保存上次的数据. 相关知识 Serialization ,ScriptableO ...
- VS的快捷键F12改成和ECLIPSE一样用ctrl+点击下载线
安装resharper 插件即可 不过这个插件是收费的,可免费体验30天
- plsqldevloper + orcal环境搭建
移动信息安全的漏洞和逆向原理 程序员11月书讯,评论得书啦 Get IT技能知识库,50个领域一键直达 关闭 PL/SQL Developer安装配置实践 2014-04-23 1 ...
- java 22 - 20 多线程之线程池
程序启动一个新线程成本是比较高的,因为它涉及到要与操作系统进行交互. 而使用线程池可以很好的提高性能,尤其是当程序中要创建大量生存期很短的线程时,更应该考虑使用线程池. 线程池里的每一个线程代码结束后 ...
- Cornerstone 哪些错误
1.Unable to connect to a repository at URl.............,The operation could not be completed 说明无法连接的 ...
- angular的uiRouter服务学习(5) --- $state.includes()方法
$state.includes方法用于判断当前激活状态是否是指定的状态或者是指定状态的子状态. $state.includes(stateOrName,params,options) $state.i ...
- 用sql查询当天,一周,一个月的数据
用sql查询当天,一周,一个月的数据 数据查询,不管在网站还是在系统,都很常见,下文是介绍最常见的以日期查询的语句 select * from ShopOrder where datediff(w ...
- DWZ中Tree树形菜单的treeCheck如何获取返回值解决方案
最近在对DWZ和asp.net MVC3进行整合,其中遇到了很多问题,总算一一解决了,今天就说说题目所示的问题解决方案. 想做一个基于角色的权限管理,要对每一个Action进行权限控制.就想用DWZ的 ...
- 《程序设计教学法--以Java程序设计为例》
<程序设计教学法--以Java程序设计为例> 当老师上的第一门课就是<Java程序设计>,工作以来,断断续续上了近十次课了吧.十几年来,教材.课程内容.教学方法.教学手段不断改 ...