POJ1737 连通图
一句话题意:求一个 \(n\) 点带编号的连通图数量。
吐槽一下:好好一道计数 dp 为什么不加取余????逼着选手写高精度的出题人应该拎出去烧……哦楼天城是出题人是吧哦当我没说我什么都没说我现在就把我拎出去 QAQ
这道题就很计数 dp 那个味对吧,所以设 \(f_i\) 为 \(i\) 个点的连通图数量。
但这样非常难算,你想我们数数 dp 是围绕一个基准,按照这个基准来划分子问题,一个连通图拿什么当基准?正难则反,考虑计算不连通图的数量,因为这样每一个连通块就自然而然给了我们划分出来子问题的空间了。我们记 \(g_i\) 为 \(i\) 个点非连通图数量。以下为了叙述方便我们令 \(b2_{i} = 2^{(i - 1)i / 2}\),放在这题的含义就是:有 \(i\) 个点共能产生多少张图。
我们先考虑 1 号点,以 1 号点所在连通块大小作为我们划分的基准,这样就分成了一些子问题了。我们令一号店所在连通块大小为 \(k\),也就是说除了 \(1\) 点外要选 \((k - 1)\) 个点。这样的连通块一共有 \(C_{n - 1}^{k - 1}\) 种。连通块内部有 \(f(k)\) 种方案。连通块外部呢?管它的,随便它们联通不联通,反正只要不和我们选出来的 \((k - 1)\) 个点和 \(1\) 连边就好了。所以答案就是 \(g_{x} = \sum\limits_{k = 1}^{x - 1}C_{x - 1}^{k - 1}f_xb2_{x - k}, f_x = b2_{x} - g_{x}\)
毒瘤就毒瘤在写高精度,这玩意儿就算是暴力都好久没写了,很担心自己哪里细节写挂了,反正高精度打了七八十来行,高兴极了
//SIXIANG
#include <iostream>
#include <algorithm>
#include <string>
#include <cstring>
#define MAXN 100000
#define QWQ cout << "QWQ" << endl;
using namespace std;
struct Bignum {
string num;
Bignum operator + (const Bignum &other) const {
string s1 = num, s2 = other.num, rest = "";
if(s1.size() < s2.size()) swap(s1, s2);
while(s2.size() < s1.size()) s2 = "0" + s2;
reverse(s1.begin(), s1.end());
reverse(s2.begin(), s2.end());
int len = s1.size(), a = 0, b = 0, c = 0, d = 0;
for(int p = 0; p < len; p++) {
a = s1[p] - '0', b = s2[p] - '0';
c = (a + b + d) % 10, d = (a + b + d) / 10;
rest += char(c + '0');
}
if(d) rest += char(d + '0');
reverse(rest.begin(), rest.end());
string ans = "";
bool lead = 0;
for(int p = 0; p < rest.size(); p++) {
if(!lead)
if(rest[p] != '0')
lead = 1;
if(lead)
ans += rest[p];
}
return (Bignum){ans};
}
Bignum operator - (const Bignum &other) const {
string s1 = num, s2 = other.num;
while(s2.size() < s1.size()) s2 = "0" + s2;
reverse(s1.begin(), s1.end());
reverse(s2.begin(), s2.end());
int a = 0, b = 0, c = 0, d = 0;
string rest = "", ans = "";
for(int p = 0; p < s1.size(); p++) {
a = s1[p] - '0', b = s2[p] - '0';
c = a + d - b;
if(c < 0) c += 10, d = -1;
else d = 0;
rest += char(c + '0');
}
bool lead = 0;
for(int p = rest.size() - 1; p >= 0; p--) {
if(!lead)
if(rest[p] != '0')
lead = 1;
if(lead)
ans += rest[p];
}
return (Bignum){ans};
}
Bignum operator * (const Bignum &other) const {
string s1 = num, s2 = other.num;
reverse(s1.begin(), s1.end());
reverse(s2.begin(), s2.end());
int a[5010], b[5010], c[10010];
memset(a, 0, sizeof(a));
memset(b, 0, sizeof(b));
memset(c, 0, sizeof(c));
int len1 = s1.size(), len2 = s2.size();
for(int p = 0; p < len1; p++)
a[p] = s1[p] - '0';
for(int p = 0; p < len2; p++)
b[p] = s2[p] - '0';
for(int p = 0; p < len1; p++)
for(int i = 0; i < len2; i++)
c[p + i] += a[p] * b[i];
for(int p = 0; p <= len1 + len2; p++)
c[p + 1] += c[p] / 10, c[p] %= 10;
bool lead = 0;
string rest = "";
for(int p = len1 + len2 + 1; p >= 0; p--) {
if(!lead)
if(c[p] != 0)
lead = 1;
if(lead)
rest += char(c[p] + '0');
}
return (Bignum){rest};
}
};
Bignum b2[1260], C[60][60], f[260], g[260];
int n;
int id(int n) {return n * (n - 1) / 2;}
void prepare() {
b2[0].num = "1";
for(int p = 1; p <= 1250; p++)
b2[p] = b2[p - 1] * (Bignum){"2"};
for(int p = 0; p <= 55; p++)
for(int i = 0; i <= 55; i++)
C[p][i].num = "0";
C[0][0].num = C[1][0].num = C[1][1].num = "1";
for(int p = 2; p <= 55; p++) {
C[p][0].num = "1";
for(int i = 1; i <= p; i++)
C[p][i] = C[p - 1][i - 1] + C[p - 1][i];
}
f[1].num = "1", g[1].num = "0";
for(int p = 2; p <= 55; p++)
f[p].num = g[p].num = "0";
for(int i = 2; i <= 50; i++) {
for(int k = 1; k < i; k++) {
Bignum tmp = C[i - 1][k - 1] * f[k] * b2[id(i - k)];
g[i] = g[i] + tmp;
}
f[i] = b2[id(i)] - g[i];
}
}
int init() {
cin >> n;
if(!n) return -1;
cout << f[n].num << endl;
}
int main() {
prepare();
while(1)
if(init() < 0) return 0;
}
POJ1737 连通图的更多相关文章
- [poj1737]Connected Graph(连通图计数)
题意:输出题中带有$n$个标号的图中连通图的个数. 解题关键: 令$f(n)$为连通图的个数,$g(n)$为非联通图的个数,$h(n)$为总的个数. 则$f(n) + g(n) = h(n)$ 考虑标 ...
- BZOJ 3237: [Ahoi2013]连通图
3237: [Ahoi2013]连通图 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1161 Solved: 399[Submit][Status ...
- dfs判断连通图(无向)
在图论中,连通图基于连通的概念.在一个无向图 G 中,若从顶点vi到顶点vj有路径相连(当然从vj到vi也一定有路径),则称vi和vj是连通的.如果 G 是有向图,那么连接vi和vj的路径中所有的边都 ...
- bfs判断连通图(无向)
在图论中,连通图基于连通的概念.在一个无向图 G 中,若从顶点vi到顶点vj有路径相连(当然从vj到vi也一定有路径),则称vi和vj是连通的.如果 G 是有向图,那么连接vi和vj的路径中所有的边都 ...
- 【poj1737】 Connected Graph
http://poj.org/problem?id=1737 (题目链接) 题意 求n个节点的无向连通图的方案数,不取模w(゚Д゚)w Solution 刚开始想了个第二类斯特林数,然而并不知道怎么求 ...
- POJ1737 Connected Graph
Connected Graph Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 3156 Accepted: 1533 D ...
- POJ2762 Going from u to v or from v to u?(判定单连通图:强连通分量+缩点+拓扑排序)
这道题要判断一张有向图是否是单连通图,即图中是否任意两点u和v都存在u到v或v到u的路径. 方法是,找出图中所有强连通分量,强连通分量上的点肯定也是满足单连通性的,然后对强连通分量进行缩点,缩点后就变 ...
- 无向连通图求割边+缩点+LCA
Network Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 7082 Accepted: 2555 Descripti ...
- Noip2014 提高组 T2 联合权值 连通图+技巧
联合权值 描述 无向连通图 G 有 n 个点,n-1 条边.点从 1 到 n 依次编号,编号为 i 的点的权值为 WiWi, 每条边的长度均为 1.图上两点(u, v)的距离定义为 u 点到 v 点的 ...
- [kuangbin带你飞]专题九 连通图
ID Origin Title 76 / 163 Problem A POJ 1236 Network of Schools 59 / 177 Problem B UVA 315 Ne ...
随机推荐
- 规则引擎Drools在贷后催收业务中的应用
作者:vivo 互联网服务器团队- Feng Xiang 在日常业务开发工作中我们经常会遇到一些根据业务规则做决策的场景.为了让开发人员从大量的规则代码的开发维护中释放出来,把规则的维护和生成交由业务 ...
- vulnhub靶场之CONTAINME: 1
准备: 攻击机:虚拟机kali.本机win10. 靶机:CONTAINME: 1,下载地址:https://download.vulnhub.com/containme/THM-ContainMe-v ...
- GitHub上的一个笔记相关小项目
就是一个笔记屑小项目, C++编写,有想一起开发的私信 AlgorithWeaver/V-note (github.com) 项目名V-note QVQ
- Shell及Linux常见易错题目题库-Shell/Linux-选择、简答、判断、编程
1.以下不合法的shell头是(不合法指运行会报错)( ) A. #!/bin/bash B. #-/bin/bash C. !#/bin/bash 答案:C 2.if [ $2 -a $2 = ...
- python虚拟环境和venv的使用
目录 1.环境与虚拟环境 2.查看帮助 3.--system-site-package 命令 4.创建虚拟环境 5.激活/关闭虚拟环境 6.保存和复制虚拟环境 7.改变虚拟环境所指向的真实python ...
- 为什么总是应该考虑给定 List 的初始大小
在 .Net 技术中,使用 List<> 来存储数据是很常见的.List<> 是一个可以动态增长的泛型集合类型,可以存储任何类型的数据. 但是,在实际使用中,很多人并不注意给定 ...
- python 之异常捕获及处理(try--except)
在python中,至少有两类错误,一种是程序语法错误,一种是程序异常. 所谓的语法错误是指你未按规定格式书写导致的错误,如:定义函数时,括号后面要紧跟英文冒号,若缺失则不能识别与运行,并抛出 Synt ...
- 第一百一十七篇: JavaScript 工厂模式和原型模式
好家伙,本篇为<JS高级程序设计>第八章"对象.类与面向对象编程"学习笔记 1.工厂模式 工厂模式是另外一种关注对象创建概念的创建模式. 它的领域中同其它模式的不同 ...
- 9、手写一个starter
一.starte详解: 1.starter场景启动器: SpringBoot-starter是一个集成接合器,主要完成两件事: (1).引入模块所需的相关jar包 (2).自动配置各自模块所需的属性 ...
- [0x12] 135.最大子序和【单调队列】
我在知乎上看到一句话,如一道晴天霹雳: "如果一个选手比你小还比你强,你就可以退役了."--单调队列的原理 题意 link(more:P1714) 给定一个长度为 \(n\) 的整 ...