谈论最激烈的莫过于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. java系列:《java核心技术 卷1》学习笔记,chapter 11 调试技巧

    11. 6 调试技巧 1)一个不太为人所知却非常有效的技巧是在每个类中放一个main方法,这样就可以对每个类进行单元测试.这个方法可以保留,因为在java虚拟机只调用启动类的main方法. 2)   ...

  2. Linux第十一次学习笔记

    异常控制流 异常控制流(ECF)发生在计算机系统的各个层次 在硬件层,硬件检测到的事件会触发控制突然转移到异常处理程序. 在操作系统层,内核通过上下文转换将控制从一个用户进程转移到另一个用户进程. 在 ...

  3. 获取技能的成功经验和关于C语言学习的调查 2015528

    内容提要 你有什么技能比大多人(超过90%以上)更好?针对这个技能的获取你有什么成功的经验?与老师博客中的学习经验有什么共通之处? 有关C语言学习的调查 你是怎么学习C语言的?(作业,实验,教材,其他 ...

  4. 给ubuntu开通FTP功能

    一.安装vsftp安装: sudo apt-get install vsftpd 二.启动.停止.重启vsftp 启动vsftp:sudo service vsftpd start 三.创建ftp用户 ...

  5. 浅析C#中的“==”和Equals

    1.“==”和Equals两个真的有关联吗? 对于“==”和Equals大多数网友都是这样总结的: “==” 是比较两个变量的值相等. Equals是比较两个变量是否指向同一个对象. 如:这篇文章,并 ...

  6. struts2+Hibernate实现用户登陆功能

    实现的功能,在登陆页面输入Username和PassWord后,将username和password通过Hibernate匹对数据库是否含有一样的username和password,若有则登陆进去,若 ...

  7. 在ubuntu server上安装沸腾时刻环境

    1. 安装php5.6 http://phpave.com/upgrade-to-php-56-on-ubuntu-1404-lts/ 按照这篇文章的顺序来做,可以安装最新5.6版本php 安装好了以 ...

  8. Use Windows Azure AD to create SSO projects

    Keywords Windows Azure AD, SSO Summary Use Windows Azure AD to create SSO projects Detailed Scenario ...

  9. 第九章:Javascript类和模块

    (过年了,祝大家新年好!) 第6章详细介绍了javascript对象,每个javascript对象都是一个属性集合,相互之间没有任何联系.在javascript中也可以定义对象的类,让每个对象都共享某 ...

  10. nginx + Lua 实现自定义WAF

    文章摘自:https://github.com/unixhot/waf wget git@github.com:unixhot/waf.git