把我坑到死的题

开始开题以为是全图连通是的最小值 ,以为是最小生成树,然后敲了发现不是,看了下别人的题意,然后懂了;

然后发现数据大,要用邻接表就去学了一下邻接表,然后又去学了下优先队列优化的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的更多相关文章

  1. HDU 1535 Invitation Cards(逆向思维+邻接表+优先队列的Dijkstra算法)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1535 Problem Description In the age of television, n ...

  2. NBOJv2——Problem 1037: Wormhole(map邻接表+优先队列SPFA)

    Problem 1037: Wormhole Time Limits:  5000 MS   Memory Limits:  200000 KB 64-bit interger IO format: ...

  3. Prime邻接表+优先队列

    #include <iostream> #include <cmath> #include <cstring> #include <cstdlib> # ...

  4. Genealogical tree(拓扑结构+邻接表+优先队列)

    Genealogical tree Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 131072/65536K (Java/Other) ...

  5. HDU 2544 最短路(邻接表+优先队列+dijstra优化模版)

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  6. 基于STL优先队列和邻接表的dijkstra算法

    首先说下STL优先队列的局限性,那就是只提供入队.出队.取得队首元素的值的功能,而dijkstra算法的堆优化需要能够随机访问队列中某个节点(来更新源点节点的最短距离). 看似可以用vector配合m ...

  7. 06-图1 列出连通集 (25分)(C语言邻接表实现)

    题目地址:https://pta.patest.cn/pta/test/558/exam/4/question/9495 由于边数E<(n*(n-1))/2 所以我选用了邻接表实现,优先队列用循 ...

  8. SDUT2142数据结构实验之图论二:基于邻接表的广度优先搜索遍历

    http://acm.sdut.edu.cn/sdutoj/showproblem.php?pid=2142&cid=1186 题目描述 给定一个无向连通图,顶点编号从0到n-1,用广度优先搜 ...

  9. Invitation Cards(邻接表+逆向建图+SPFA)

    Time Limit: 8000MS   Memory Limit: 262144K Total Submissions: 17538   Accepted: 5721 Description In ...

随机推荐

  1. OAuth2学习及DotNetOpenAuth部分源码研究

    OAuth2学习及DotNetOpenAuth部分源码研究 在上篇文章中我研究了OpenId及DotNetOpenAuth的相关应用,这一篇继续研究OAuth2. 一.什么是OAuth2 OAuth是 ...

  2. 关于PHP上传文件和中文名乱码情况

    关于PHP文件上传 在前端HTML页面,表单如下 Upload.html <!doctype html><html lang="en"><head&g ...

  3. java 25 - 4 网络编程之 UDP协议传输的代码优化

    UDP协议的输出端: /* UDP发送数据: A:创建Socket发送端对象 B:创建数据报包(把数据打包) C:调用Socket对象发送数据报包 D:释放资源(底层是IO流) */ public c ...

  4. View.inflate和LayoutInflater的inflate方法区别

    平时ListView加载item中,adapter的getView方法中,我们经常用到: LayoutInflater.from(mContext).inflate(R.layout.it ,pare ...

  5. Android 下载网络图片保存到本地

    通过网络地址获取网络图片,点击下载将图片显示出来,然后点击图片将图片保存到本地. 首先需要在manifest上添加一些权限: <!-- 访问网络的权限 --> <uses-permi ...

  6. 对于大量left join 的表查询,可以在关键的 连接节点字段上创建索引。

    对于大量left join 的表查询,可以在关键的 连接节点字段上创建索引. 问题: 大量的left join 怎么优化 select a.id,a.num,b.num,b.pcs,c.num, c. ...

  7. TRIM函数

    Trim() 删除字符串首尾的空白(可以首尾一起,也可以指定首或尾,取决于控制参数),但会保留字符串内部作为词与词之间分隔的空格.

  8. javascript数组对象排序

    javascript数组对象排序 JavaScript数组内置排序函数 javascript内置的sort函数是多种排序算法的集合 JavaScript实现多维数组.对象数组排序,其实用的就是原生的s ...

  9. Java synchronized

    1. 将synchronized加在方法上, 即可实现对此方法的同步 public synchronized void deposit(float amt) { float tmp = amount; ...

  10. 无法连接windows虚拟机oracle的解决办法

    在mac机上玩基于oracle db的开发真心不容易,oracle公司死活不出oracle express edition for mac OS,曾经发布过的oracle 10 for mac下载地址 ...