CCF真题之最优灌溉
#include<bits/stdc++.h> //该头文件包含C++所有头文件(编程中显得非常方便,很省时间)
//#include <vector> //若无以上头文件,则需要添加下面这两个头文件才不会报错
//#include <iostream>
using namespace std;
const int maxn=1007;
const int inf=10001;
int n,m; struct node {
int to,cost;
};
bool vis[maxn];
//表示从当前节点到 d[i]节点的距离 ,首先初始化均为无穷大,之后,每找到一个点,则修改其邻接点的最小距离,其他点仍为无穷大
int d[maxn];
vector<node> G[maxn];
void init() {
for(int i=0;i<maxn;i++) {
G[i].clear();
}
}
//最小生成数prim,CCF中可以直接调用
int prim() {
int ans=0;
/* memset(vis,0,sizeof(vis));
memset(dis,100001,sizeof(d));*/ 使用memset初始化结果会溢出,具体原因不清楚
for(int i=1;i<maxn;i++) {
d[i]=inf;
vis[i]=0;
}
d[1]=0;
while(1){ //注释部分用于调试理解代码
//for(i=1;i<=n;i++)
//cout<<d[i]<<" ";
//cout<<endl;
int v=-1;
for(int i=1;i<=n;i++) {
//if(!vis[i]&&v==-1)用来保证只要还有未通过的点,则就可以从当前最后通过的点,找到下一个未通过的点
//if(!vis[i]&&d[i]<d[v])表示与当前通过的点可能连接多个相邻的未通过的点, 故需要找出距离最小的相邻的未通过的点
//这里只可能是当前最后通过的点的所有相邻点,因为只要找到一个点,则对其进行标记通过,再修改其相邻点的距离 ,未相邻点仍为无穷大
if(!vis[i]&&(v==-1||d[i]<d[v])) v=i;
//cout<<"...."<<v<<endl;
}
if(v==-1) break;
vis[v]=1;
ans+=d[v];
for(int i=0;i<G[v].size();i++) {
if(vis[G[v][i].to]) continue;
d[G[v][i].to]=min(d[G[v][i].to],G[v][i].cost);
}
}
return ans;
}
int main() {
int a,b,c; node n1;
while(cin>>n>>m){
init();
for(int i=0;i<m;i++) {
cin>>a>>b>>c;
n1.to=b;n1.cost=c;
G[a].push_back(n1);
n1.to=a;
G[b].push_back(n1);
}
int ans=prim();
cout<<ans<<endl;
//用于检测每个节点的邻接节点以及权值是否正确
/*for(int i=1;i<=n;i++) {
for(int j=0;j<G[i].size();j++)
cout<<G[i][j].to<<" "<<G[i][j].cost<<endl;
}*/ }
}
若CCF中再次考到最小生成树,但是输入方式为:
第一行为:给定n个点,表示当前有多少块麦田
接下来n行表示:
每块麦田之间是否相连接以及相应的权值
如该题输入方式可改为:
4
0 1 0 0
1 0 4 2
0 4 0 3
0 2 3 0
node n1;
while(cin>>n){
init();
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
{
cin>>a;
if(a!=0)
{
n1.to=j+1;n1.cost=a;
G[i+1].push_back(n1);
n1.to=i+1;
G[j+1].push_back(n1);
}
}
int ans=prim();
cout<<ans<<endl;
//用于检测每个节点的邻接节点以及权值是否正确
/*for(int i=1;i<=n;i++) {
for(int j=0;j<G[i].size();j++)
cout<<G[i][j].to<<" "<<G[i][j].cost<<endl;
}*/ }
}
CCF真题之最优灌溉的更多相关文章
- CCF真题Z型输出
#include<stdio.h> #include<iostream> #include<string.h> #include<algorithm> ...
- CCF真题之命令行选项
201403-3 问题描述 请你写一个命令行分析程序,用以分析给定的命令行里包含哪些选项.每个命令行由若干个字符串组成,它们之间恰好由一个空格分隔.这些字符串中的第一个为该命令行工具的名字,由小写字母 ...
- CCF真题之最大矩形
201312-3 问题描述 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i(1 ≤ i ≤ n)个矩形的高度是hi.这n个矩形构成了一个直方图.例如,下图中六个矩形的高度就分别是3, 1, 6 ...
- CCF真题之节日
201503-3 问题描述 有一类节日的日期并不是固定的,而是以“a月的第b个星期c”的形式定下来的,比如说母亲节就定为每年的五月的第二个星期日. 现在,给你a,b,c和y1, y2(1850 ≤ y ...
- CCF真题之字符串匹配
201409-3 问题描述 给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行.你的程序还需支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符:当选项关闭时,表示同一 ...
- CCF真题之网络延时
201503-4 问题描述 给定一个公司的网络,由n台交换机和m台终端电脑组成,交换机与交换机.交换机与电脑之间使用网络连接.交换机按层级设置,编号为1的交换机为根交换机,层级为1.其他的交换机都连接 ...
- CCF真题之Z字形扫描
201412-2 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z字形扫描的过程如下图所示: 对于下面的4×4的矩阵, 1 5 ...
- CCF真题之门禁系统
201412-1 问题描述 涛涛最近要负责图书馆的管理工作,需要记录下每天读者的到访情况.每位读者有一个编号,每条记录用读者的编号来表示.给出读者的来访记录,请问每一条记录中的读者是第几次出现. 输入 ...
- CCF真题之画图
201409-2 问题描述 在一个定义了直角坐标系的纸上,画一个(x1,y1)到(x2,y2)的矩形指将横坐标范围从x1到x2,纵坐标范围从y1到y2之间的区域涂上颜色. 下图给出了一个画了两个矩形的 ...
随机推荐
- GATT 服务器与客户端角色
两个设备应用数据的通信是通过协议栈的GATT层实现的.从GATT角度来看,当两个设备建立连接后,他们处于以下两种角色之一: GATT服务器: 它是为GATT客户端提供数据服务的设备 GATT客户端: ...
- freebsd上安装nginx+php记录
参考文章 https://wiki.freebsdchina.org/faq/ports http://www.vpsee.com/2014/04/install-nginx-php-apc-mysq ...
- JVM学习笔记
1. JVM中的直接引用和符号引用 JVM在装载class文件的时候,会有一步是将符号引用解析为直接引用的过程. 那么这里的直接引用到底是什么呢? 对于指向“类型”[Class对象].类变量.类方法的 ...
- isset和empty比较
PHP的isset()函数 一般用来检测变量是否设置 格式:bool isset ( mixed var [, mixed var [, ...]] ) 功能:检测变量是否设置 返回值: 若变量不存在 ...
- 怎么清除file控件的文件路径
还记得上次做一个文件上传,后来测试告诉我说,如果我要是不选择文件了呢?该怎么办?我说:简单啊,做一个取消按钮不就完事了吗!然后我就想一个file空间做一个取消是多么简单的事,用js处理可是想怎么样就怎 ...
- CocoaPods的安装及使用/利用开源库Diplomat实现分享及第三方登录/git的使用
<<史上最简洁版本>> 1.gem sources -l查看 当前的源 //1.1 sudo -i..以下都是以管理员的身份来操作的 2.gem sources --remov ...
- Android Annotations 注解例子
1.AndroidAnnotations官网: http://androidannotations.org/ (也许你需要FQ) 2.eclipse中使用androidannotations的配置方法 ...
- Sequential Read Ahead For SQL Server
Balancing CPU and I/O throughput is essential to achieve good overall performance and to maximize ha ...
- [Logstash]使用详解(转)
Logstash是一款轻量级的日志搜集处理框架,可以方便的把分散的.多样化的日志搜集起来,并进行自定义的处理,然后传输到指定的位置,比如某个服务器或者文件. 本文针对官方文档进行翻译以及实践,希望有更 ...
- memory leak at strcore.cpp
最近使用CString出现了内存泄露,后来发现是CString.GetBuffer之后没有ReleaseBuffer.