38-布线问题

内存限制:64MB
时间限制:1000ms
Special Judge: No

accepted:5
submit:11

题目描述:

南阳理工学院要进行用电线路改造,现在校长要求设计师设计出一种布线方式,该布线方式需要满足以下条件:
1、把所有的楼都供上电。
2、所用电线花费最少

输入描述:

第一行是一个整数n表示有n组测试数据。(n<5)
每组测试数据的第一行是两个整数v,e.
v表示学校里楼的总个数(v<=500)
随后的e行里,每行有三个整数a,b,c表示a与b之间如果建铺设线路花费为c(c<=100)。(哪两栋楼间如果没有指明花费,则表示这两栋楼直接连通需要费用太大或者不可能连通)
随后的1行里,有v个整数,其中第i个数表示从第i号楼接线到外界供电设施所需要的费用。( 0<e<v*(v-1)/2 )
(楼的编号从1开始),由于安全问题,只能选择一个楼连接到外界供电设备。
数据保证至少存在一种方案满足要求。

输出描述:

每组测试数据输出一个正整数,表示铺设满足校长要求的线路的最小花费。

样例输入:

复制

1
4 6
1 2 10
2 3 10
3 1 10
1 4 1
2 4 1
3 4 1
1 3 5 6

样例输出:

4

分析:
  ①、他要求的布线情况(因为一定有结果)就是求图的最短路径问题
  ②、我们可以考虑右prim算法
    1、prim算法就是由任意一个点开始找最短的路径
    2、在前一个的基础上我们可以得到两个点且改两个点已经连接上
    3、现在我们要找的就是经过第一个或第二个点的最小路径
    4、依次循环直到遍历所有的点
 ③、从外面连入的线我们直接根据升序排序,再取最小的值
 ④、两者相加即为结果 核心代码(prim模板):
 int prim()
{
int cnt = , pos = , my_weight[n+], my_book[n+] = {, }; // cnt表示最小的布线情况
for(int i = ; i <= n; ++ i)
if(!my_book[i])
my_weight[i] = my_map[pos][i];
for(int i = ; i < n; ++ i)
{
int my_min = MAXNUM;
for(int j = ; j <= n; ++ j)
{
if(!my_book[j] && my_weight[j] < my_min)
{
my_min = my_weight[j];
pos = j;
}
}
cnt += my_min;
my_book[pos] = ;
for(int j = ; j <= n; ++ j)
{
if(!my_book[j] && my_weight[j] > my_map[j][pos])
my_weight[j] = my_map[j][pos];
}
}
return cnt;
}

C/C++代码实现(AC):

 #include <bits/stdc++.h>

 using namespace std;
const int MAXN = ;
const int MAXNUM = 0x3f3f3f3f;
int my_map[MAXN][MAXN], n, m, my_line[MAXN]; int prim()
{
int cnt = , pos = , my_weight[n+], my_book[n+] = {, }; // cnt表示最小的布线情况
for(int i = ; i <= n; ++ i)
if(!my_book[i])
my_weight[i] = my_map[pos][i];
for(int i = ; i < n; ++ i)
{
int my_min = MAXNUM;
for(int j = ; j <= n; ++ j)
{
if(!my_book[j] && my_weight[j] < my_min)
{
my_min = my_weight[j];
pos = j;
}
}
cnt += my_min;
my_book[pos] = ;
for(int j = ; j <= n; ++ j)
{
if(!my_book[j] && my_weight[j] > my_map[j][pos])
my_weight[j] = my_map[j][pos];
}
}
return cnt;
} int main()
{
int t;
scanf("%d", &t);
while(t --)
{
scanf("%d%d", &n, &m);
for(int i = ; i <= n; ++ i)
for(int j = ; j <= n; ++ j)
my_map[i][j] = MAXNUM;
for(int i = ; i < m; ++ i)
{
int a, b, c;
scanf("%d%d%d", &a, &b, &c);
my_map[a][b] = my_map[b][a] = c;
} for(int i = ; i < n; ++ i)
scanf("%d", &my_line[i]);
sort(my_line, my_line + n, less<int>());
printf("%d\n", my_line[] + prim());
}
return ;
}

nyoj 38-布线问题(prim, sort)的更多相关文章

  1. NYOJ 38布线问题

    http://acm.nyist.net/JudgeOnline/problem.php?pid=38 布线问题 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 南阳 ...

  2. NYOJ 38 布线问题_(解法2 Prim算法)

    时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描写叙述 南阳理工学院要进行用电线路改造.如今校长要求设计师设计出一种布线方式.该布线方式须要满足下面条件: 1.把全部的楼都供 ...

  3. nyoj 38 布线问题 Kruskal and Prim

    布线问题 时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描述 南阳理工学院要进行用电线路改造,现在校长要求设计师设计出一种布线方式,该布线方式需要满足以下条件: 1.把所有的 ...

  4. NYOJ 38 布线问题 (最小生成树 prim)

    题目链接 描述 南阳理工学院要进行用电线路改造,现在校长要求设计师设计出一种布线方式,该布线方式需要满足以下条件: 1.把所有的楼都供上电. 2.所用电线花费最少 输入 第一行是一个整数n表示有n组测 ...

  5. NYOJ 38 布线问题_(解法1 Kruskal算法)

    时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描写叙述 南阳理工学院要进行用电线路改造.如今校长要求设计师设计出一种布线方式,该布线方式须要满足下面条件: 1.把全部的楼都供 ...

  6. nyoj 38 布线问题

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=38 最小生成树水题~ 代码: #include "stdio.h" / ...

  7. [图论]最优布线问题:prim

    最优布线问题 目录 最优布线问题 Description Input Output Sample Input Sample Output Hint 解析 代码 Description 学校有n台计算机 ...

  8. 【待修改】nyoj 38 最小生成树

    package nyoj; import java.util.Scanner; public class Main { public static void main(String args[]) { ...

  9. NYIST OJ 题目38 布线问题

    最小生成树水题,先按最小生成树做,答案最后加上最小的从第i号楼接线到外界供电设施所需要的费用即可. #include<cstdio> #include<cstring> #in ...

随机推荐

  1. 前端知识点总结——jQuery(下)

    1. 排队和并发 1.并发: 多个css属性同时变化放在一个animate函数内的多个css属性默认并发变化 2.排队: 多个css属性先后变化对同一个元素,先后调用多个动画API,都是排队执行原理: ...

  2. Redis集群与高可用性技术小结

    客户端分片,这种方式需要实现特定的客户端,需要手工配置redis实例并根据算法进行访问,对于redis实例的增减,调整灵活性很差,一般不推荐. 代理分片,常见的有Twemproxy架构(豆瓣创建了co ...

  3. spring boot 2.x文件路径映射问题汇总

    当我们在运行可执行的java jar包的时候,我们肯定改变不了jar里面的内容,因此文件上传路径就成了我们必须考虑的一点问题,我们不能往直接这个jar包里面写文件,那么只能写在jar包外面,但是写到j ...

  4. Spring容器启动源码解析

    1. 前言 最近搭建的工程都是基于SpringBoot,简化配置的感觉真爽.但有个以前的项目还是用SpringMvc写的,看到满满的配置xml文件,却有一种想去深入了解的冲动.折腾了好几天,决心去写这 ...

  5. java学习-IDEA相关使用

    1.配置git与github(用于将代码提交到GitHub) 添加自己的github账号 2.提交代码到github 登录https://github.com,即可看到刚刚提交到github的代码仓库 ...

  6. 网络攻防实验任务三_(2)X-Scan通用漏洞扫描实验

    首先在宿主机中打开xscan_gui.exe,结果系统直接将它删掉了. 大概是因为开了防火墙的缘故. 于是我在win7虚拟机中运行这个程序. 并且关闭防火墙,在win7中可以运行 我再试了一下win1 ...

  7. human_pose_estimation_demo的进一步研究

    一.demo能力 OpenVINO提供了范例(human_pose_estimation_demo),能够在CPU上以较快速度识别出多人 -iE:/OpenVINO_modelZoo/head-pos ...

  8. Leetcode Tags(3)String(TODO)

    一.Easy 696 Count Binary Substrings Input: "00110011" Output: 6 Explanation: There are 6 su ...

  9. 设计模式(十一)Composite模式

    Composite模式模式能够使容器与内容具有一致性,创造出递归结构.有时,与将文件夹和文件都作为目录条目看待一样,将容器和内容作为同一种东西看待,可以帮助我们方便地处理问题.在容器中既可以放入内容, ...

  10. Golang的安装和编译

    一.下载安装(Ubuntu16.04) 1.下载地址:https://golang.google.cn/dl/ 2.下载Linux版本的安装包go1.10.3.linux-amd64.tar.gz并复 ...