谈论最激烈的莫过于D题了!

看过的两种做法不得不ORZ,特别第二种,简直神一样!!!!!

1th:构造最小生成树。

我们提取所有的边出来按边排序,因为每次我们知道边的权值>0,

之后每次把边加入集合中,不断构造,类似  kruskal算法,构造出边后

再对每个点进行整张图的DFS求距离

复杂度O(N^2lgN):对所有边排序的复杂度。

 #include<bits/stdc++.h>

 #define N 2222
using namespace std;
typedef long long ll;
#define inf 0x3f3f3f
int n;
int f[N],vis[N];
int a[N][N]; struct node
{
int u,v,w;
node(int uu,int vv,int ww):u(uu),v(vv),w(ww){}
}; vector<pair<int,int> > G[N];
vector<node> edge; int find(int x)
{if (f[x]!=x) return f[x]=find(f[x]);} int cmp(node a,node b){return a.w<b.w;} ll dis[N];
void dfs(int x)
{
vis[x]=;
// cout<<dis[x]<<" ";
for (int i=;i<G[x].size();i++)
{
int v=G[x][i].first;
int w=G[x][i].second;
if (vis[v]) continue;
dis[v]=dis[x]+w;
dfs(v);
}
} int solve()
{
for (int i=;i<n;i++)
for (int j=i+;j<=n;j++)
edge.push_back(node(i,j,a[i][j])); for (int i=;i<=n;i++) f[i]=i; sort(edge.begin(),edge.end(),cmp);
int t=edge.size();
for (int i=;i<t;i++)
{
int x=edge[i].u;
int y=edge[i].v;
int tx=find(x);
int ty=find(y);
if (tx!=ty)
{
f[tx]=ty;
G[x].push_back(make_pair(y,edge[i].w));
G[y].push_back(make_pair(x,edge[i].w));
}
} for (int i=;i<=n;i++)
{
memset(vis,,sizeof(vis));
memset(dis,,sizeof(dis));
dfs(i); for (int j=;j<=n;j++)
if (dis[j]!=a[i][j])
{
return ;
}
}
return ;
} int main()
{ scanf("%d",&n);
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
scanf("%d",&a[i][j]); for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
{
if (a[i][j]!=a[j][i]||i==j&&a[i][j]!=)
{
puts("NO");
return ;
}
if (i!=j&&a[i][j]==)
{
puts("NO");
return ;
}
} if (solve()) puts("YES");
else puts("NO");
return ;
}

代码可能更好说明思路,关键一点是:我们每次把最短的边加入集合。我们确定这是一颗最小生成树!所以加边次序是和MST是一样的。

第二种做法不得不佩服!1

这个特种点很难在比赛中发现啊

关键点:我们知道一个点到其他所有点都有一条最小距离的边--假设A到其他点最小距离的点是B,A-B一定是直接连接的。假设距离是X。

然后假设一个点C,C到B点要么比C到A点近X,要么C到A点远X。具体可以画图。

通过这个方法可以判断数据是否合法!

代码超级短

 #include<bits/stdc++.h>
typedef long long ll;
using namespace std;
#define N 2222 int a[N][N];
int n;
int main()
{
scanf("%d",&n);
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
scanf("%d",&a[i][j]); //预处理判断
int flag=;
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
{
if (i!=j&&a[i][j]==) flag=;
if (i==j&&a[i][j]!=) flag=;
if (i!=j&&a[i][j]!=a[j][i]) flag=;
} if (flag)
{
puts("NO");
return ;
} for (int i=;i<=n;i++)
{
int inf= ;//初始的值要比较大些
int pos=-;
for (int j=;j<=n;j++){
if (i==j) continue;
if (a[i][j]<inf)
{
inf =a[i][j];
pos=j;
}
}
for (int j=;j<=n;j++)
{
if (i==j||j==pos) continue;
if (abs(a[i][j]-a[pos][j])!=inf)
{
puts("NO");
return ;
}
}
} puts("YES");
return ;
} 后面的基本是水体了:
C:贪心:
从第一的判断每次找合理值,矛盾就错误!
B:
我是用贪心的做法!
想想我们最后电梯还是要回到第一层!对吧!
也要走到最高层,当前有人想去的最高层!
那么我们每次把前K高层的先送上去!就能满足答案最小!
 #define N 111111
using namespace std; int a[];
int cmp(int x,int y)
{
return x>y;
}
int main()
{
int n,k;
cin>>n>>k; for (int i=;i<=n;i++) cin>>a[i];
sort(a+,a+n+,cmp);
int ans=;
for (int i=;i<=n;i+=k)
ans+=(a[i]-)*; cout<<ans<<endl;
return ;

复杂度O(N^2);时间600MS;这是快


Codeforces Round #270 D C B A的更多相关文章

  1. Codeforces Round #270 1003

    Codeforces Round #270 1003 C. Design Tutorial: Make It Nondeterministic time limit per test 2 second ...

  2. Codeforces Round #270 1002

    Codeforces Round #270 1002 B. Design Tutorial: Learn from Life time limit per test 1 second memory l ...

  3. Codeforces Round #270 1001

    Codeforces Round #270 1001 A. Design Tutorial: Learn from Math time limit per test 1 second memory l ...

  4. Codeforces Round #270 A~D

    Codeforces Round #270 A. Design Tutorial: Learn from Math time limit per test 1 second memory limit ...

  5. Codeforces Round #270(利用prim算法)

    D. Design Tutorial: Inverse the Problem time limit per test 2 seconds memory limit per test 256 mega ...

  6. codeforces水题100道 第七题 Codeforces Round #270 A. Design Tutorial: Learn from Math (math)

    题目链接:http://www.codeforces.com/problemset/problem/472/A题意:给你一个数n,将n表示为两个合数(即非素数)的和.C++代码: #include & ...

  7. 多种方法过Codeforces Round #270的A题(奇偶法、打表法和Miller_Rabin(这个方法才是重点))

    题目链接:http://codeforces.com/contest/472/problem/A 题目: 题意:哥德巴赫猜想是:一个大于2的素数一定可以表示为两个素数的和.此题则是将其修改为:一个大于 ...

  8. Codeforces Round #270 D Design Tutorial: Inverse the Problem --MST + DFS

    题意:给出一个距离矩阵,问是不是一颗正确的带权树. 解法:先按找距离矩阵建一颗最小生成树,因为给出的距离都是最短的点间距离,然后再对每个点跑dfs得出应该的dis[][],再对比dis和原来的mp是否 ...

  9. Codeforces Round #270

    A 题意:给出一个数n,求满足a+b=n,且a+b均为合数的a,b 方法一:可以直接枚举i,n-i,判断a,n-i是否为合数 #include<iostream> #include< ...

随机推荐

  1. ubuntu16.04安装eclipse

    1.下载jdk , jdk-8u77-linux-x64.tar.gz 2.下载 eclipse, eclipse-jee-mars-2-linux-gtk-x86_64.tar.gz 注:我下载的都 ...

  2. 坑死我啊,一个WPF Adorner使用注意事项

    1.见鬼了? 项目中遇到这样的要求,一个Button用一个Adorner装饰,这个Adorner上又有一个Button,如下面这样 此时,我们在点击小Button的时候只希望处理小Button的事件, ...

  3. c# 技巧之 泛型方法

    泛型 指的是编译时不需要指定具体的参数类型,可以在运行时动态地赋予某一种数据类型的机制.  相信很多人对泛型类并不陌生,像Dictionary,List等结构都属于泛型类.有趣的是,一个函数/方法也可 ...

  4. Linux下线程池的理解与简单实现

    首先,线程池是什么?顾名思义,就是把一堆开辟好的线程放在一个池子里统一管理,就是一个线程池. 其次,为什么要用线程池,难道来一个请求给它申请一个线程,请求处理完了释放线程不行么?也行,但是如果创建线程 ...

  5. 第十章 使用MapKit

    本项目是<beginning iOS8 programming with swift>中的项目学习笔记==>全部笔记目录 ------------------------------ ...

  6. 第二章:Javascript词法结构

    编程语言的词法结构是一套基础性的规则,用来描述你如何编写这门语言.作为语法的基础,它规定了变量名是怎么样的,如何写注释,以及语句之间是如何区分的.本节用很短的篇幅来介绍javascript的词法结构. ...

  7. mysqldump使用方法

    1.mysqldump的几种常用方法: (1)导出整个数据库(包括数据库中的数据) mysqldump -u username -p dbname > dbname.sql (2)导出数据库结构 ...

  8. jQuery Mobile学习日记(二)

    首先依HTML5方式加载,DOCTYPE表示格式为HTML5:主要适用于iPhone.Android等,viewport表示适用于移动终端的适中显示,initial-scale缩放比例在1.0~1.3 ...

  9. 视频播放用户行为记录之使用Cache的方法

    在上一篇文章http://www.cnblogs.com/ryuasuka/p/3483632.html中,为了获取视频播放时的用户行为,并且要异步地将其写入XML文件中,我采用了先写入log,后生成 ...

  10. ansible 配置运行环境

    P34 2.3.1 配置ansible的环境 ansible的配置文件是以ini格式存储配置数据的,在ansible中几乎所有的配置都可以通过playbook或者环境变量来重新赋值 运行ansible ...