关于可图化序列的一点结论 NEU 1429
Graphic Sequence
A graphic sequence is a sequence of numbers which can be the degree sequence of some graph. A sequence can be checked to determine if it is graphic using GraphicQ[g] in the Mathematica package Combinatorica` .
Erdős and Gallai (1960) proved that a degree sequence  is graphic iff the sum of vertex degrees is even and the sequence obeys the property
 is graphic iff the sum of vertex degrees is even and the sequence obeys the property
|  | 
for each integer  (Skiena 1990, p. 157), and this condition also generalizes to directed graphs. Tripathi and Vijay (2003) showed that this inequality need be checked only for as many
 (Skiena 1990, p. 157), and this condition also generalizes to directed graphs. Tripathi and Vijay (2003) showed that this inequality need be checked only for as many  as there are distinct terms in the sequence, not for all
 as there are distinct terms in the sequence, not for all  .
.
Havel (1955) and Hakimi (1962) proved another characterization of graphic sequences, namely that a degree sequence with  =3" style="border-width: 0px; vertical-align: middle;"> and
=3" style="border-width: 0px; vertical-align: middle;"> and  =1" style="border-width: 0px; vertical-align: middle;"> is graphical iff the sequence
=1" style="border-width: 0px; vertical-align: middle;"> is graphical iff the sequence  is graphical. In addition, Havel (1955) and Hakimi (1962) showed that if adegree sequence is graphic, then there exists a graph
 is graphical. In addition, Havel (1955) and Hakimi (1962) showed that if adegree sequence is graphic, then there exists a graph  such that the node of highest degree is adjacent to the
 such that the node of highest degree is adjacent to the  next highest degree vertices of
 next highest degree vertices of  , where
, where  is the maximum degree of
 is the maximum degree of  .
.
No degree sequence can be graphic if all the degrees occur with multiplicity 1 (Behzad and Chartrand 1967, p. 158; Skiena 1990, p. 158). Any degree sequence whose sum is even can be realized by a multigraph having loops (Hakimi 1962; Skiena 1990, p. 158).
很不错的一个定理: 就是给出一个度序列,然后 判读这个度序列是不是可图的当且仅当 满足 : sigma<1,r>(di) <= k*(k-1) +sigma<k+1,n> min(k,di)
( 0< k<=n )
注意到定理中要求 sigma<k+1,n> min(k,di) ; 所以我们可以二分找出度数大于k的区间求出其前缀和即可 时间复杂的达到 O(nlogn) 然后套公式就行了。
其实还有另外一个定理: havel定理,不是怎么实用的定理感觉是 。 网上题解代码 复杂度都是O(n^2logn) 没事水数据玩都是。 还扯些没用的优化,
好像可以计数排序写复杂度是O(n^2) 省赛还是被卡掉的。 O(nlogn) 还挺快>_<。
给出一道题:
1429: Traveling
题目描述
SH likes traveling around the world. When he arrives at a city, he will ask the staff about the number of cities that connected with this city directly. After traveling around a mainland, SH will collate data and judge whether the data is correct.
A group of data is correct when it can constitute an undirected graph.
输入
There are multiple test cases. The first line of each test case is a positive integer N (1<=N<=10000) standing for the number of cities in a mainland. The second line has N positive integers a1, a2, ...,an. ai stands for the number of cities that connected directly with the ith city. Input will be ended by the END OF FILE.
输出
If a group of data is correct, output "YES" in one line, otherwise, output "NO".
样例输入
8 7 7 4 3 3 3 2 1 10 5 4 3 3 2 2 2 1 1 1
样例输出
NO YES
1 #include<cstdio>
2 #include<cstring>
3 #include<algorithm>
4 using namespace std;
5 const int MAX = 1e5;
6 int deg[MAX],sum[MAX],sum2[MAX];
7 int cmp(int a,int b) {return a>b ;}
8 int n;
9 int check() {
if(sum[n]&) return ;
for(int k=;k<=n;k++) {
int L=k+,R=n; int ans;
while(L<=R) {
int mid=(R+L) >> ;
if(deg[mid]>=k) ans=mid,L=mid+;
else R=mid-;
}
sum2[k]=k*(ans-k)+sum[n]-sum[ans];
}
int ans;
for(int i=;i<=n;i++) {
if(sum[i]<=i*(i-)) continue;
ans=sum2[i];
// for(int k=i+1;k<=n;k++) ans+=min(i,deg[k]);
if(sum[i]>i*(i-)+ans) return ;
}
return ;
}
int main() {
while(scanf("%d",&n)==) {
memset(sum,,sizeof(sum));
memset(sum2,,sizeof(sum2));
for(int i=;i<=n;i++) scanf("%d",°[i]);
sort(deg+,deg+n+,cmp);
for(int i=;i<=n;i++) sum[i]=sum[i-] + deg[i];
int ret=check();
if(ret) printf("YES\n");
else printf("NO\n");
}
}
/**************************************************************
Problem: 1429
User: 20124906
Language: C++
Result: 正确
Time:201 ms
Memory:1960 kb
****************************************************************/
关于可图化序列的一点结论 NEU 1429的更多相关文章
- Havel--Hakimi定理推断可图化 python
		介绍: 哈维尔[1955]--哈吉米[1962]算法能够用来判读一个度序列d是否是可图化的. 哈维尔[1955]--哈吉米[1962]定理: 对于N > 1,长度为N的度序列d可以可图化当且仅当 ... 
- UML精粹3 - 类图,序列图,CRC
		类图Class diagram 类图描述系统中的对象类型,以及它们之间的各种静态关系.类图也展示类的性质和操作,以及应用于对象连接方式的约束.UML中的特性feature,涵盖了性质property和 ... 
- Havel-Hakimi定理---通过度数列判断是否可图化
		0.可图:一个非负整数组成的序列如果是某个无向图的度序列,则该序列是可图的. 1.度序列:Sequence Degree,若把图G所有顶点的度数排成一个序列,责成该序列为图G的一个序列.该序列可以是非 ... 
- 从 Java 代码逆向工程生成 UML 类图和序列图
		from:http://blog.itpub.net/14780914/viewspace-588975/ 本文面向于那些软件架构师,设计师和开发人员,他们想使用 IBM® Rational® Sof ... 
- Android图表库MPAndroidChart(七)—饼状图可以再简单一点
		Android图表库MPAndroidChart(七)-饼状图可以再简单一点 接上文,今天实现的是用的很多的,作用在统计上的饼状图,我们看下今天的效果 这个效果,我们实现,和之前一样的套路,我先来说下 ... 
- 【51Nod】1510 最小化序列   贪心+动态规划
		[题目]1510 最小化序列 [题意]给定长度为n的数组A和数字k,要求重排列数组从而最小化: \[ans=\sum_{i=1}^{n-k}|A_i-A_{i+k}|\] 输出最小的ans,\(n \ ... 
- poj 1659 Frogs' Neighborhood 度序列可图化 贪心
		题意: 对一个无向图给出一个度序列,问他是否可简单图化. 分析: 依据Havel定理,直接贪心就可以. 代码: //poj 1659 //sep9 #include <iostream> ... 
- Visio画UML类图、序列图 for Java
		参考文档: 1.百度搜索: 怎样用Visio 2007画C++类图 连接 https://jingyan.baidu.com/article/9f7e7ec07286e16f281554f7.html ... 
- 【BZOJ1049】【Luogu P2501】 [HAOI2006]数字序列  DP,结论,LIS
		很有(\(bu\))质(\(hui\))量(\(xie\))的一个题目. 第一问:求最少改变几个数能把一个随机序列变成单调上升序列. \(Solution:\)似乎是一个结论?如果两个数\(A_i\) ... 
随机推荐
- apache的安全增强配置(使用mod_chroot,mod_security)
			apache的安全增强配置(使用mod_chroot,mod_security) 作者:windydays 2010/8/17 LAMP环境的一般入侵,大致经过sql注入,上传webshel ... 
- Zuul 网关搭建
			本机IP为 192.168.1.102 1. 新建 Maven 项目 zuul 2. pom.xml <project xmlns="http://maven.apac ... 
- ThreadLocal为什么要用WeakReference
			先上一张图看一下ThreadLocal的内部结构,每个Thread对象内部都维护了一个ThreadLocal.ThreadLocalMap 我们在上图看到的就是三个Thread对象内部格子的Threa ... 
- 转:Python集合(set)类型的操作
			转自:http://blog.csdn.net/business122/article/details/7541486 python的set和其他语言类似, 是一个无序不重复元素集, 基本功能包括关系 ... 
- ASP.NET补充
			字典类的子集 using System.Collections.Generic; Dictionary<string, string> dicB = new Dictionary<s ... 
- 【SQL】连接 —— 内连接、外连接、左连接、右连接、交叉连接
			连接 · 内连接 · 外连接 · 左连接 · 右连接 · 全连接 · 交叉连接 · 匹配符号(+) 连接 根据表之间的关系,呈现跨表查询的结果. 外连接 内连接 左连接 右连接 全 ... 
- js点击拉拽轮播图pc端移动端适配
			<div class="content"> <button class="left">left</button> <b ... 
- PAM认证机制
			PAM:Pluggable Authentication Modules 认证库:文本文件,MySQL,NIS,LDAP等 Sun公司于1995 年开发的一种与认证相关的通用框架机制 PAM 是关注如 ... 
- Flask学习笔记:数据库迁移操作flask-script+alembic/flask-migrate
			数据库迁移是将代码中模型类(即表)的修改同步到数据库中, flask-sqlalchemy的模型类一旦使用create_all()映射到数据库中后,对这个模型类的修改(例如添加了一个新的字段)就不会再 ... 
- Play on Words HDU - 1116 (并查集 + 欧拉通路)
			Play on Words HDU - 1116 Some of the secret doors contain a very interesting word puzzle. The team o ... 
