人活着系列之芳姐和芳姐的猪

Time Limit: 1000MS Memory limit: 65536K

题目描写叙述

芳姐特别喜欢猪,所以,她特意养了m个猪圈,顺便在k条无向边,每条边有都有起点v,距离.....芳姐和猪们约定好。每天去一个固定猪圈去吃饭。芳姐为了不累着她可爱的猪们,想知道全部的猪吃饭走的最短路程是多少?

输入

 第一行,猪的个数m(k(1<=k<=1200).(猪的编号为1..m)

N+1行N头猪所在的猪圈号第n+k+1行:u、1<=w<=255)

m个猪圈连通。

输出

 

演示样例输入

3 4 5
2
3
4
1 2 1
1 3 5
2 3 7
2 4 3
3 4 5

演示样例输出

8

提示


開始以为,崔老师坑我们,不是最短路,就打成了最小生成树。kurskal

感觉思路没错,没有的猪圈。就不加边。╮(╯▽╰)╭,挂了20遍。没过

错误代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
const int INF = 65535;
using namespace std;
struct node{
int u,v,w;
}edge[1300];
int n,m,father[610],l;
bool vis[610];
int cmp(const void *a ,const void *b)
{
struct node *X,*Y;
X = (struct node *)a;
Y = (struct node *)b;
return X->w - Y->w;
}
void init()
{
l = 0;
for(int i = 0;i<=m;i++)
father[i] = i;
}
int findx(int r)
{
int i ,j;
while(r!=father[r])
{
r= father[r];
}
i = r;
while(father[i]!=r)
{
j = father[i];
father[i] = r;
i = j;
}
return r;
}
void kruskal()
{
int ans = 0;
for(int i = 0;i<=l;i++)
{
int uu = findx(edge[i].u);
int vv = findx(edge[i].v);
// printf("%d->%d = %d\n",edge[i].u,edge[i].v,edge[i].w);
if(uu!=vv)
{
father[uu] = vv;
ans += edge[i].w;
}
}
printf("%d\n",ans);
}
int main()
{
int mm, a , b,c,k;
scanf("%d%d%d",&n,&m,&k);
init();
for(int i = 1;i<=m;i++)
vis[i] = 1; for(int i = 0;i<n;i++)
{
scanf("%d",&mm);
vis[mm] = 0;
}
for(int i = 0;i<k;i++)
{
scanf("%d%d%d",&a,&b,&c);
if(vis[a]==1 || vis[b]==1) continue; edge[l].u = a; edge[l].v = b; edge[l++].w = c;
}
qsort(edge,l,sizeof(edge[0]),cmp);
kruskal();
return 0;
}

AC


后台数据比較水

#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#define INF 0x3f3f3f3f
using namespace std; int n,m,KKK;
int ma[651][651],a[400]; void init()
{
int i,j;
for(i=1; i<=m;i++)
{
for( j=1; j<=m; j++)
{
if(i==j) ma[i][j] = 0;
else ma[i][j]=INF;
}
}
}
int main()
{ int u,v,w,i,j,k;
scanf("%d%d%d",&n,&m,&KKK);
//puts("1");
init(); for(i=1; i<=n; i++)
{
scanf("%d",&a[i]);
} for(i = 0;i<KKK;i++)
{
scanf("%d%d%d",&u,&v,&w);
ma[u][v]=ma[v][u]=w;
} for( k=1; k<=m; k++)
{
for( i=1; i<=m; i++)
{
for( j=1; j<=m; j++)
{
if(ma[i][j] > ma[i][k] + ma[k][j])
{
ma[i][j] = ma[i][k] + ma[k][j];
}
}
}
} int sum , mi = INF;
for(i=1; i<=m; i++)
{
sum=0;
for(j=1; j<=n; j++)
{
sum += ma[i][a[j]];
}
if(sum < mi)
mi = sum;
} printf("%d\n",mi);
return 0;
} /*****************************

版权声明:本文博客原创文章。博客,未经同意,不得转载。

人活着系列Tanya和蔡健雅猪 (floyd)的更多相关文章

  1. 人活着系列之平方数 分类: sdutOJ 2015-06-22 17:10 7人阅读 评论(0) 收藏

    人活着系列之平方数 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 偶然和必然?命运与意志?生与死?理性与情感?价值与非价值?在&quo ...

  2. SDUT OJ 之 人活着系列之寻找最完美的人生

    人活着系列之寻找最完美的人生 Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述 也许,人活着就是要尝试人世间的酸甜苦辣,喜怒哀乐,经 ...

  3. 人活着系列之芳姐和芳姐的猪(Floyd)

    http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2929 这个题一方面数据水,另一方面就是思维水, ...

  4. sdut 2934 人活着系列之平方数 (完全背包变形)

    题目链接 分析:完全背包的变形,每一层的d[]数组代表这一层的这个数新加入以后所构成的val的种类. #include <iostream> #include <cstdio> ...

  5. 小P的故事——神奇的换零钱&&人活着系列之平方数

    http://acm.sdut.edu.cn/sdutoj/showproblem.php?pid=2777&cid=1219 这题不会,看了别人的代码 #include <iostre ...

  6. 人活着系列之开会(Floy)

    http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2930 题意:所有点到Z点的最短距离.因为岛名由 ...

  7. 人活系列Streetlights (秩)

    人活着系列之Streetlights Time Limit: 1000MS Memory limit: 65536K 题目描写叙述 人活着假设是为了家庭,亲情----能够说是在这个世界上最温暖人心的, ...

  8. SDUT 2933-人活着系列Streetlights(最小生成树Kruskal+和理查德设置来实现)

    人活着系列之Streetlights Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描写叙述 人活着假设是为了家庭,亲情----能够说 ...

  9. HDU-4511 小明系列故事——女友的考验 floyd变种-标号递增最短路

    题意:给定N个点,现在要求出从1号点到N号点的最短路.题目给的限制条件就是对于某条路径是不能够走的,但是可以选择某段路径走,另外就是所走的路径的标号必须是递增的. 分析:由于给定的是一些列的坐标点,这 ...

随机推荐

  1. iOS开发Quartz2D之十二:手势解锁实例

    一:效果如图: 二:代码: #import "ClockView.h" @interface ClockView() /** 存放的都是当前选中的按钮 */ @property ( ...

  2. Android 利用线程运行栈StackTraceElement设计Android日志模块

    如果你想在你的Android程序中自动打印MainActivity.onCreate(line:37)这种类名.方法名(行数)的日志该如何实现呢? 1.引入Java的线程运行栈 Java.lang包中 ...

  3. Uncaught SyntaxError: Unexpected end of input 解决办法

    Unexpected end of input  的英文意思是"意外的终止输入" 他通常表示我们浏览器在读取我们的js代码时,碰到了不可预知的错误,导致浏览器 无语进行下面的读取 ...

  4. 2016.3.14__CSS 定位__第六天

    假设您认为这篇文章还不错.能够去H5专题介绍中查看很多其它相关文章. CSS 定位机制 CSS中一共同拥有三种基本定位机制:普通流.浮动.绝对定位. 假设不进行专门指定.全部的标签都在普通流中定位. ...

  5. js中如何删除某个元素下面的所有子元素?(两种方法)

    js中如何删除某个元素下面的所有子元素?(两种方法) 一.总结 方法一:通过元素的innerHTML属性 元素element.innerHTML=""; 方法二:通过元素的remo ...

  6. js时间和时间戳之间如何转换(汇总)

    js时间和时间戳之间如何转换(汇总) 一.总结 一句话总结: 1.js中通过new Date()来获取时间对象, 2.这个时间对象可以通过getTime()方法获取时间戳, 3.也可以通过getYea ...

  7. Indy10 控件的使用(2)TidTCpServer组件学习

    以下来自英文原版帮助文件,文桓英语不好,翻译了老半天.有错误的地方见谅,别骂我. TIdTCPServer = class(TIdComponent) Description TIdTCPServer ...

  8. C#基础readonly 与const

    readonly 与 const readonly是运行时常量,const是编译期常量(在编译过程中已经把使用该值的都用值替代,不分配内存)readonly灵活性高,const效率高 readonly ...

  9. Spring MVC出现POST 400 Bad Request &405 Request method 'GET' not supported

    首先描述一下出现错误的情景: 我刚学springmvc,想做一个登录界面的东西.然后试着写了一个controller如下: @RequestMapping(value = "/login&q ...

  10. 【hdu2825】ac自动机 + 状压dp

    传送门 题目大意: 给你一些密码片段字符串,让你求长度为n,且至少包含k个不同密码片段串的字符串的数量. 题解: 因为密码串不多,可以考虑状态压缩 设dp[i][j][sta]表示长为i的字符串匹配到 ...