POJ1737 Connected Graph
Time Limit: 1000MS | Memory Limit: 30000K | |
Total Submissions: 3156 | Accepted: 1533 |
Description
You are to write a program that tries to calculate the number of different connected undirected graph with n vertices.
For example,there are 4 different connected undirected graphs with 3 vertices.

Input
input contains several test cases. Each test case contains an integer n,
denoting the number of vertices. You may assume that 1<=n<=50.
The last test case is followed by one zero.
Output
Sample Input
- 1
- 2
- 3
- 4
- 0
Sample Output
- 1
- 1
- 4
- 38
Source
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
- INPUT:
- OUTPUT:
打表
然后是我一直改不对的代码
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- #include<cmath>
- using namespace std;
- struct bgnum{
- int l;
- int a[];
- bgnum operator + (const bgnum &x) const{
- bgnum ans;
- memset(ans.a,,sizeof(ans.a));
- int len=max(l,x.l);
- ans.l=;
- for(int i=;i<=len;i++){
- ans.a[i]+=a[i]+x.a[i];
- ans.a[i+]+=ans.a[i]/;
- ans.a[i]%=;
- }
- len++;
- while(!ans.a[len]&&len)len--;
- ans.l=len;
- return ans;
- }
- bgnum operator - (const bgnum &x) const{
- bgnum ans;
- memset(ans.a,,sizeof(ans.a));
- for(int i=;i<=l;i++){
- ans.a[i]+=a[i]-x.a[i];
- if(ans.a[i]<){
- ans.a[i]+=;
- ans.a[i-]--;
- }
- }
- ans.l=l;
- while(!ans.a[ans.l] && ans.l) ans.l--;
- return ans;
- }
- bgnum operator * (const bgnum &x) const{
- bgnum ans;
- memset(ans.a,,sizeof(ans.a));
- for(int i=;i<=l;i++)
- for(int j=;j<=x.l;j++){
- ans.a[i+j-]+=a[i]*x.a[j];
- ans.a[i+j]+=ans.a[i+j-]/;
- ans.a[i+j-]%=;
- }
- int len=l+x.l;
- while(!ans.a[len] && len)len--;
- ans.l=len;
- return ans;
- }
- }f[],//[i]个点构不同图的方案数
- c[][],//[i]个点中选[j]个任意连边的方案数
- mi[],//2的[i]次方
- sum;
- void Print(bgnum p){
- for(int i=p.l;i>=;i--){
- printf("%d",p.a[i]);
- }
- printf("\n");
- return;
- }
- bgnum p1,p2;
- int main(){
- p1.l=;p1.a[]=;//高精度数1
- p2.l=;p2.a[]=;//高精度数2
- int i,j;
- mi[]=p1;
- for(i=;i<=;i++)
- mi[i]=mi[i-]*p2;
- for(i=;i<=;i++)
- c[i][]=p1;
- for(i=;i<=;i++)
- for(j=;j<=i;j++){
- c[i][j]=c[i-][j]+c[i-][j-];//组合数递推公式
- }
- for(i=;i<=;i++){
- sum.l=;
- memset(sum.a,,sizeof(sum.a));
- for(j=;j<i;j++){
- sum=sum+(c[i-][j-]*f[j]*mi[(i-j)*(i-j-)/]);
- }
- // Print(sum);
- f[i]=mi[i*(i-)/]-sum;
- }
- int n;
- scanf("%d",&n);
- Print(f[n]);
- return ;
- }
再放隔壁某dalao的AC题解
http://blog.csdn.net/orion_rigel/article/details/51812864
POJ1737 Connected Graph的更多相关文章
- 【Java】【高精度】【组合数】【递推】poj1737 Connected Graph
http://blog.csdn.net/sdj222555/article/details/12453629 这个递推可以说是非常巧妙了. import java.util.*; import ja ...
- [poj1737]Connected Graph(连通图计数)
题意:输出题中带有$n$个标号的图中连通图的个数. 解题关键: 令$f(n)$为连通图的个数,$g(n)$为非联通图的个数,$h(n)$为总的个数. 则$f(n) + g(n) = h(n)$ 考虑标 ...
- $Poj1737\ Connected\ Graph$ 计数类$DP$
AcWing Description 求$N$个节点的无向连通图有多少个,节点有标号,编号为$1~N$. $1<=N<=50$ Sol 在计数类$DP$中,通常要把一个问题划分成若干个子问 ...
- poj 1737 Connected Graph
// poj 1737 Connected Graph // // 题目大意: // // 带标号的连通分量计数 // // 解题思路: // // 设f(n)为连通图的数量,g(n)为非连通图的数量 ...
- POJ 1737 Connected Graph 题解(未完成)
Connected Graph Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 3156 Accepted: 1533 D ...
- Connected Graph
Connected Graph 求n个点的无向联通图数量,\(n\leq 50\). 解 直接无向联通图做状态等于是以边点做考虑,难以去重,考虑联通对立面即不联通. 不难求出n个点的总方案数为\(2^ ...
- 【poj1737】 Connected Graph
http://poj.org/problem?id=1737 (题目链接) 题意 求n个节点的无向连通图的方案数,不取模w(゚Д゚)w Solution 刚开始想了个第二类斯特林数,然而并不知道怎么求 ...
- POJ 1737 Connected Graph(高精度+DP递推)
题面 \(solution:\) 首先做个推销:带负数的压位高精度(加减乘+读写) 然后:由 \(N\) 个节点组成的无向图的总数为: \(2^{N*(N-1)/2}\) (也就是说这个图总共有 \( ...
- POJ 1737 Connected Graph (大数+递推)
题目链接: http://poj.org/problem?id=1737 题意: 求 \(n\) 个点的无向简单(无重边无自环)连通图的个数.\((n<=50)\) 题解: 这题你甚至能OEIS ...
随机推荐
- 关于eclipse入门开发c/c++文章推荐
1. 关于编译说明. http://www.ibm.com/developerworks/cn/linux/opensource/os-ecc/ 2. 关于快捷键与代码阅读 http://www.cn ...
- iOS获取窗口当前显示的控制器
解决类似网易新闻客户端收到新闻推送后,弹出一个UIAlert,然后跳转到新闻详情页面这种需求 1.提供一个UIView的分类方法,这个方法通过响应者链条获取view所在的控制器 - (UIViewCo ...
- 13SpringMvc_限定某个业务控制方法,只允许GET或POST请求方式访问
这篇文章要实现的功能是:在一个Action中,有些业务方法只能是post提交上来的才能执行,有些方法是只能get提交上来的才能执行. 比如上篇文章中的UserAction.java(代码如下) pac ...
- 【转】【C#】在 Windows 窗体 DataGridView 单元格中承载控件
using System; using System.Windows.Forms; public class CalendarColumn : DataGridViewColumn { public ...
- 如何免费访问Google?
访问Google方法(以Mac为例) 1.替换hosts文件中的内容,文件链接如下: https://github.com/racaljk/hosts 2.下载Google浏览器,链接如下: http ...
- 公钥(Public Key)与私钥(Private Key)
公钥(Public Key)与私钥(Private Key)是通过一种算法得到的一个密钥对(即一个公钥和一个私钥),公钥是密钥对中公开的部分,私钥则是非公开的部分.公钥通常用于加密会话密钥.验证数字签 ...
- XML CDATA的作用
操作XML文件时,如果允许用户输入内容,例如∶"< ".">"."/".""等,当生成XML时,会破坏了XM ...
- 『方案』《女友十年精华》 ORC 图片 文字识别 详解
目的需求: 2008年,遇到一本电子书 <女友十年精华> 觉得很美,想 私藏 这些文章: >网络搜索文章 —— 没有找到: >反编译程序 —— 所有文字 都是图片格式(部分文章 ...
- IOS判断app在appstore是否有可用的更新
iTunes可以提供app的版本信息,主要通过appid获取,如 http://itunes.apple.com/lookup?id=946449501,使用时只需要到iTunes查找自己的appid ...
- linux网络命令
关键字 write wall last lastlog traceroute netstat mount 1.write 该命令可以给所有在线用户发送消息 示例: 接受消息用户:按回车可以退出 2.w ...