Codeforces Round #270 D C B A
谈论最激烈的莫过于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的更多相关文章
- Codeforces Round #270 1003
Codeforces Round #270 1003 C. Design Tutorial: Make It Nondeterministic time limit per test 2 second ...
- Codeforces Round #270 1002
Codeforces Round #270 1002 B. Design Tutorial: Learn from Life time limit per test 1 second memory l ...
- Codeforces Round #270 1001
Codeforces Round #270 1001 A. Design Tutorial: Learn from Math time limit per test 1 second memory l ...
- Codeforces Round #270 A~D
Codeforces Round #270 A. Design Tutorial: Learn from Math time limit per test 1 second memory limit ...
- Codeforces Round #270(利用prim算法)
D. Design Tutorial: Inverse the Problem time limit per test 2 seconds memory limit per test 256 mega ...
- codeforces水题100道 第七题 Codeforces Round #270 A. Design Tutorial: Learn from Math (math)
题目链接:http://www.codeforces.com/problemset/problem/472/A题意:给你一个数n,将n表示为两个合数(即非素数)的和.C++代码: #include & ...
- 多种方法过Codeforces Round #270的A题(奇偶法、打表法和Miller_Rabin(这个方法才是重点))
题目链接:http://codeforces.com/contest/472/problem/A 题目: 题意:哥德巴赫猜想是:一个大于2的素数一定可以表示为两个素数的和.此题则是将其修改为:一个大于 ...
- Codeforces Round #270 D Design Tutorial: Inverse the Problem --MST + DFS
题意:给出一个距离矩阵,问是不是一颗正确的带权树. 解法:先按找距离矩阵建一颗最小生成树,因为给出的距离都是最短的点间距离,然后再对每个点跑dfs得出应该的dis[][],再对比dis和原来的mp是否 ...
- Codeforces Round #270
A 题意:给出一个数n,求满足a+b=n,且a+b均为合数的a,b 方法一:可以直接枚举i,n-i,判断a,n-i是否为合数 #include<iostream> #include< ...
随机推荐
- [CareerCup] 7.4 Implement Multiply Subtract and Divide 实现乘法减法和除法
7.4 Write methods to implement the multiply, subtract, and divide operations for integers. Use only ...
- [CareerCup] 8.6 Jigsaw Puzzle 拼图游戏
8.6 Implement a jigsaw puzzle. Design the data structures and explain an algorithm to solve the puzz ...
- UIView的layoutSubviews和drawRect方法何时调用 ———转
转自:http://jianyu996.blog.163.com/blog/static/112114555201305113018814/ 首先两个方法都是异步执行.layoutSubviews方便 ...
- 慢牛系列三:React Native实践
上次发布了我的慢牛股票APP之后,有园友反馈有点卡,这个APP是基于Sencha Touch + Cordova开发的,Sencha本身是一个比较重的框架,在Chrome里运行性能还是不错的,但是在A ...
- Thrift搭建分布式微服务(二)
第二篇 连接池 连接池配置,请前往Thrift搭建分布式微服务(一) 下面要介绍的其实不是单一的连接池,应该说是连接池集合.因为它要管理多个Tcp Socket连接节点,每个服务节点都有设置了自己 ...
- #Linux学习笔记# Linux文件的所有者、群组和其他人
1.关于所有者.群组和其他人 在Linux系统中,每个文件都具有User.Group和Others三种身份的权限配置.那这三种身份分别表示什么意思呢?配置这三种身份的权限有啥意义呢? (1)文件所有者 ...
- [USACO2005][POJ3045]Cow Acrobats(贪心)
题目:http://poj.org/problem?id=3045 题意:每个牛都有一个wi和si,试将他们排序,每头牛的风险值等于前面所有牛的wj(j<i)之和-si,求风险值最大的牛的最小风 ...
- android之显示数据库信息
关键字 ListView adapter MVC 在android开发中也使用到了MVC架构,其中的xml布局文件就是V,M就是我们定义好的javabean类,而控制器就是就是适配器类adapter ...
- shell编程之基础
1.初探shell #!/bin/bash echo -e 'hello \nworld' 执行结果 echo 是打印输出字符,-e选项是开启转义功能 注意: 在windows下编写的shell脚本直 ...
- 编写高质量代码改善C#程序的157个建议[C#闭包的陷阱、委托、事件、事件模型]
前言 本文已更新至http://www.cnblogs.com/aehyok/p/3624579.html .本文主要学习记录以下内容: 建议38.小心闭包中的陷阱 建议39.了解委托的实质 建议40 ...