当前位置: 首页 > news >正文

安徽省建设总站网站打广告去哪个平台免费

安徽省建设总站网站,打广告去哪个平台免费,山东封城最新消息2023年,如何查找网站建设时间[COCI2009-2010#7] SVEMIR 题目描述 太空帝国要通过建造隧道来联通它的 NNN 个星球。 每个星球用三维坐标 (xi,yi,zi)(x_i,y_i,z_i)(xi​,yi​,zi​) 来表示,而在两个星球 A,BA,BA,B 之间建造隧道的价格为 min⁡{∣xA−xB∣,∣yA−yB∣,∣zA−zB∣}\min\{|x_A-x_…

[COCI2009-2010#7] SVEMIR

题目描述

太空帝国要通过建造隧道来联通它的 NNN 个星球。

每个星球用三维坐标 (xi,yi,zi)(x_i,y_i,z_i)(xi,yi,zi) 来表示,而在两个星球 A,BA,BA,B 之间建造隧道的价格为 min⁡{∣xA−xB∣,∣yA−yB∣,∣zA−zB∣}\min\{|x_A-x_B|,|y_A-y_B|,|z_A-z_B|\}min{xAxB,yAyB,zAzB}

现要建造 N−1N-1N1 条隧道使得所有的星球都能直接或间接相连。求完成该任务所需的最小总价。

输入格式

第一行,一个整数 NNN

接下来的 NNN 行,每行三个整数 xi,yi,zix_i,y_i,z_ixi,yi,zi,表示第 iii 个星球的坐标。

数据保证不存在两个具有相同坐标的星球。

输出格式

输出所需的最小总价。

样例 #1

样例输入 #1

2
1 5 10
7 8 2

样例输出 #1

3

样例 #2

样例输入 #2

3
-1 -1 -1
5 5 5
10 10 10

样例输出 #2

11

样例 #3

样例输入 #3

5
11 -15 -15
14 -5 -15
-1 -1 -5
10 -4 -1
19 -4 19

样例输出 #3

4

提示

【数据规模与约定】

  • 对于 100%100\%100% 的数据,1≤N≤1051 \le N \le 10^51N105−109≤xi,yi,zi≤109-10^9 \le x_i,y_i,z_i \le 10^9109xi,yi,zi109

【提示与说明】

题目译自 COCI 2009-2010 CONTEST #7 Task 4 SVEMIR

本题分值按 COCI 原题设置,满分 100100100

最小生成树,如果把每两个点之间的边都存储,会超时超空间。
放宽条件,问题等价于每个点之间有三条边,边权分别是|x1-x2|,|y1-y2|,|z1-z2|,然后求最小生成树距离。
所以观察规律,如果按x排序,只用在相邻次序的点之间建立x插值边,分析得知相隔的点对pi,pk (|i-k|!=1)建立的x差值边一定用不上(如果这两点在两棵树上,想要连通这两棵树,选择x差值边,一
定不如它们中间一点到其中某一点的x差值边来得好)。
按照y和z排序同理。

#include <bits/stdc++.h>
#define for0(a,n) for(int (a)=0;(a)<(n);(a)++)
#define for1(a,n) for(int (a)=1;(a)<=(n);(a)++)
typedef  long long ll;using namespace std;const int maxn=1e5+0.5;
int m,n;
ll ans;
int pre[maxn+5];
struct Edge
{int u,v,w;Edge(){}Edge(int u,int v,int w):u(u),v(v),w(w){}bool operator<(const Edge & e) const{return w<e.w;}};
vector<Edge>edges;struct Node
{int x,y,z,idx;bool operator <(const Node & b) const{return x<b.x;}
} nodes[maxn+5];bool cmp_y(Node & a, Node & b) {return a.y<b.y;}
bool cmp_z(Node & a, Node & b) {return a.z<b.z;}void init()
{m=0;edges.clear();ans=0;for0(i,n+1) pre[i]=i;
}int findroot(int x) {return pre[x]==x?x: pre[x]= findroot(pre[x]);}
bool merge(int &x,int &y)
{int rootx=findroot(x);int rooty=findroot(y);if (rootx==rooty) return false;pre[rootx]=rooty;return true;
}int main()
{std::ios::sync_with_stdio(false);while(cin>>n){for1(i,n){cin>>nodes[i].x>>nodes[i].y>>nodes[i].z;nodes[i].idx=i;}init();sort(nodes+1,nodes+n+1);//        for1(i,n)
//        {
//            cout<<nodes[i].x<<" "<<nodes[i].y<<" "<<nodes[i].z;
//        }for1(i,n-1){int dis=abs(nodes[i].x-nodes[i+1].x);edges.push_back( Edge(nodes[i].idx,nodes[i+1].idx,dis));}sort(nodes+1,nodes+n+1,cmp_y);for1(i,n-1){int dis=abs(nodes[i].y-nodes[i+1].y);edges.push_back( Edge(nodes[i].idx,nodes[i+1].idx,dis));}sort(nodes+1,nodes+n+1,cmp_z);for1(i,n-1){int dis=abs(nodes[i].z-nodes[i+1].z);edges.push_back( Edge(nodes[i].idx,nodes[i+1].idx,dis));}sort(edges.begin(),edges.end());m=edges.size();//        for0(i,m)
//        {
//            cout<<edges[i].u<<" "<<edges[i].v<<" "<<edges[i].w<<endl;
//        }int T=n-1;for0(i,m){Edge & e = edges[i];int u=e.u,v=e.v,w=e.w;if(!merge(u,v)) continue;ans+= w;if (--T==0) break;}printf("%lld\n",ans);}return 0;
}
/*
2
1 5 10
7 8 23
-1 -1 -1
5 5 5
10 10 105
11 -15 -15
14 -5 -15
-1 -1 -5
10 -4 -1
19 -4 19
*/
http://www.yidumall.com/news/54964.html

相关文章:

  • wordpress创建搜索框seo技术专员招聘
  • 网站需求分析模板独立站seo
  • 东莞做外贸网站营销图片大全
  • 315晚会 网站建设公司网络营销的目的是什么
  • 做网站需要懂代码么seo+网站排名
  • 建设久久建筑网站抖音seo搜索优化
  • 南通网站制作价格网站设计论文
  • 农产品电商网站建设的主要工作微信指数查询
  • wordpress 访问人数360优化大师官方版
  • wordpress+取消边栏优化王
  • wordpress输出某一分类的文章seo概念的理解
  • wordpress 插件复制如何优化关键词的排名
  • 做设计接外快在哪个网站资阳地seo
  • 做药物分析常用网站广告联盟广告点击一次多少钱
  • 月子会所网站源码关键词搜索工具爱站网
  • 网站建设法律可行性百度竞价推广流程
  • 广州网站开发哪家专业ciliba磁力搜索引擎
  • 建设团队网站免费网站推广产品
  • 望都网站建设企业营销平台
  • 工程项目编号查询系统杭州seo博客
  • 免费优化网站建设东莞网站制作推广公司
  • 网站开发有哪些语言百度首页官网
  • 哪些网站可以做详情页百度电脑版
  • 可以做动画的网站都有哪些内容地推app接任务平台
  • 建设工程信息网重庆seo是啥意思
  • 设计企业网站机营销型网站建设
  • 怎么把网站做10万ip市场推广方案怎么做
  • 国内大的网站建设公司排名免费网站统计代码
  • 网站建设下什么费用建网站的详细步骤
  • 做宣传单赚钱的网站网站如何优化推广