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 ... 
随机推荐
- 2023年 DevOps 七大趋势
			随着时间的推移,很明显 DevOps 已经成为最高效的敏捷框架中的无人不知晓的名字.越来越多的企业(包括各类规模企业)正在采用 DevOps 方法来简化其运营效率.DevOps 的新时代趋势已经见证了 ... 
- MISC中的图片修改宽高问题
			在做CTF中MISC分类题目时,很常见的一个问题就是修改图片正确的宽与高 (此篇笔记中的内容以ctfshow中MISC入门分类为切入点,感兴趣的同学可以一边做一边有不会的看看,仅供参考,我是菜鸡) 曾 ... 
- mysql安装及访问配置
			安装教程参考:https://www.cnblogs.com/hjw-zq/p/8809227.html 下载地址:https://dev.mysql.com/downloads/mysql/ 例:h ... 
- C++动态链接MySQL库
			C++链接MySQL库 库安装目录 CMakeList cmake_minimum_required(VERSION 3.22) project(MySQLConnectionPool) includ ... 
- 论文解读(CDTrans)《CDTrans: Cross-domain Transformer for Unsupervised Domain Adaptation》
			论文信息 论文标题:CDTrans: Cross-domain Transformer for Unsupervised Domain Adaptation论文作者:Tongkun Xu, Weihu ... 
- 【云原生 • DevOps】一文掌握容器管理工具 Rancher
			一.容器管理工具 Rancher 介绍Rancher 是一个开源的企业级全栈化容器部署及管理平台,其实就是一个 Docker 的图形化管理界面.它为容器提供基础架构服务,可以让 CNI 兼容的网络服务 ... 
- Hexo博客搭建和简单部署
			title: Hexo博客搭建和简单部署 date: 2020-03-02 12:00:00 categories: - [IT,博客] - [IT,软件,程序] - [IT,软件,搭建与配置] ta ... 
- CH579(Cortex-M0)网络IAP升级介绍及问题解答--(持续更新) 网络升级
			CH579网络IAP升级的源码可以从码云(Gitee)上git clone下来. 码云地址:https://gitee.com/maji19971221/wch-ch57x 以下是一个朋友问的几个常见 ... 
- 如何指定多个项目的 InternalsVisibleTo
			InternalsVisibleTo 属性允许你指定一个或多个程序集,这些程序集可以访问当前程序集中的内部类型.经常在进行单元测试时使用,例如,你可以在一个项目中定义一个内部类型,然后在另一个项目中进 ... 
- vs2019 内核驱动编译失败:网络共享盘问题
			怀念2008 我以为这个年代了,中文路径问题应该解决了,记得vs 2008写c的时候曾因中文路径的问题导致编译不通过,从2015版本开始发现有时候项目名称和路径里包含中文也可以编译通过了,习惯之后后面 ... 
