[BZOJ1005][HNOI2008]明明的烦恼

[BZOJ1005][HNOI2008]明明的烦恼

试题描述

自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标号为1到N的点,以及某些点最终的度数,允许在
任意两点间连线,可产生多少棵度数满足要求的树?

输入

第一行为N(0 < N < = 1000),
接下来N行,第i+1行给出第i个节点的度数Di,如果对度数不要求,则输入-1

输出

一个整数,表示不同的满足要求的树的个数,无解输出0

输入示例

3
1
-1
-1

输出示例

2

数据规模及约定

见“输入

题解

知道 prufer 序列这题就是删边题了。这题不仅要写高精度,还不能随便用除法,使劲压常数,组合数要分解质因数才能过!!

= =就当练高精度吧。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <stack>
#include <vector>
#include <queue>
#include <cstring>
#include <string>
#include <map>
#include <set>
using namespace std;const int BufferSize = 1 << 16;
char buffer[BufferSize], *Head, *Tail;
inline char Getchar() {if(Head == Tail) {int l = fread(buffer, 1, BufferSize, stdin);Tail = (Head = buffer) + l;}return *Head++;
}
int read() {int x = 0, f = 1; char c = Getchar();while(!isdigit(c)){ if(c == '-') f = -1; c = Getchar(); }while(isdigit(c)){ x = x * 10 + c - '0'; c = Getchar(); }return x * f;
}#define maxn 1010
int n, deg[maxn], cnt;struct bign {int len, A[5010];bign() { len = 1; memset(A, 0, sizeof(A)); }bign operator = (const int& t) {len = 1; A[0] = t;while(A[len-1] > 9) A[len] = A[len-1] / 10, A[len-1] %= 10, len++;return *this;}void clear() {for(; !A[len-1] && len; len--) ;if(!len) len = 1;return ;}bign operator * (const int& t) const {bign ans; ans.len = len;memcpy(ans.A, A, sizeof(A));for(int i = 0; i < len; i++) ans.A[i] *= t;for(int i = 0; i < len; i++) ans.A[i+1] += ans.A[i] / 10, ans.A[i] %= 10;int j = len + 1;for(; ans.A[j-1] > 9;) ans.A[j] += ans.A[j-1] / 10, ans.A[j-1] %= 10, j++;ans.len = j;ans.clear();return ans;}bign operator *= (const int& t) {*this = *this * t;return *this;}bign operator * (const bign& t) const {bign ans; ans.len = len + t.len - 1;for(int i = 0; i < len; i++)for(int j = 0; j < t.len; j++) ans.A[i+j] += A[i] * t.A[j];for(int i = 0; i < ans.len; i++) ans.A[i+1] += ans.A[i] / 10, ans.A[i] %= 10;int j = ans.len + 1;for(; ans.A[j-1] > 9;) ans.A[j] += ans.A[j-1] / 10, ans.A[j-1] %= 10, j++;ans.len = j;ans.clear();return ans;}bign operator *= (const bign& t) {*this = *this * t;return *this;}bign operator - (const bign& t) const {bign ans; ans.len = len;memcpy(ans.A, A, sizeof(A));for(int i = 0; i < len; i++) {if(i < t.len) ans.A[i] -= t.A[i];if(ans.A[i] < 0) ans.A[i] += 10, ans.A[i+1]--;}while(!ans.A[ans.len-1]) ans.len--;return ans;}bign operator -= (const bign &t) {*this = *this - t;return *this;}bign operator / (const bign& t) const {bign ans, f; f = 0; ans.len = -1;for(int i = len - 1; i >= 0; i--) {f *= 10;f.A[0] = A[i];while(f >= t) {f -= t;ans.A[i]++;if(ans.len == -1) ans.len = i + 1;}}return ans;}bool operator >= (const bign& t) const {if(len != t.len) return len > t.len;for(int i = len - 1; i >= 0; i--) if(A[i] != t.A[i]) return A[i] > t.A[i];return 1;}void print() {for(int i = len - 1; i >= 0; i--) putchar(A[i] + '0');return ;}
} ;int prime[maxn], cp;
bool vis[maxn];
void prime_table() {for(int i = 2; i <= n; i++) {if(!vis[i]) prime[++cp] = i;for(int j = 1; j <= cp && i * prime[j] <= n; j++) {vis[i*prime[j]] = 1;if(i % prime[j] == 0) break;}}return ;
}
bign Pow(int a, int n) {bign sum, t; sum = 1; t = a;while(n) {if(n & 1) sum *= t;t *= t; n >>= 1;}return sum;
}
int Cp[maxn];
bign C(int n, int m) {for(int i = 1; i <= cp; i++) Cp[i] = 0;for(int i = n; i >= n - m + 1; i--) {int tmp = i;for(int j = 1; j <= cp; j++) if(tmp % prime[j] == 0)while(tmp % prime[j] == 0) Cp[j]++, tmp /= prime[j];}for(int i = m; i; i--) {int tmp = i;for(int j = 1; j <= cp; j++) if(tmp % prime[j] == 0)while(tmp % prime[j] == 0) Cp[j]--, tmp /= prime[j];}bign sum; sum = 1;for(int i = 1; i <= cp; i++) if(Cp[i]) sum *= Pow(prime[i], Cp[i]);return sum;
}int main() {n = read();prime_table();int tot = 0;bool ok = 1;for(int i = 1; i <= n; i++) {int x = read();if(x >= 0) deg[++cnt] = x - 1, tot += (x - 1);if(!x) ok = 0;}if(!ok || tot > n - 2) return puts("0"), 0;tot = n - 2;bign sum; sum = 1;for(int i = 1; i <= cnt; i++) {sum *= C(tot, deg[i]);tot -= deg[i];}sum *= Pow(n - cnt, tot);sum.print(); putchar('\n');return 0;
}

除法的定义其实没用,我第一次用了除法 T 飞了,现在懒得删了。

转载于:https://www.cnblogs.com/xiao-ju-ruo-xjr/p/5743709.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/372538.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android调用so封装jni,GitHub - Michelle0716/AndroidJniDemo1: 安卓对c进行so文件打包,并以jni的形式进行调用...

AndroidJniDemo1安卓对c进行so文件打包&#xff0c;并以jni的形式进行调用项目中的部分app &#xff1a; 编译so文件jniDemo: 添加运行so文件开发环境&#xff1a;android studio 3.0.1(As3.0以上创建项目&#xff0c;选择支持c/c,项目会自动生成需要的配置&#xff0c;不需要在…

ADF任务流:页面片段的托管bean范围

介绍 当我们使用ADF任务流并需要实现一些特定于流的业务逻辑或存储一些与该流相关的信息时&#xff0c;我们通常使用pageFlowScope托管bean。 而且&#xff0c;当我们需要为流的活动&#xff08;页面或页面片段&#xff09;提供服务时&#xff0c;我们将较短的作用域用于此类托…

Linux平台下:块设备、裸设备、ASMlib、Udev相关关系

对磁盘设备&#xff08;裸分区&#xff09;的访问方式分为两种&#xff1a;1.字符方式访问&#xff08;裸设备&#xff09;&#xff1b;2.块方式访问 Solaris平台 : 在Solaris平台下&#xff0c;系统同时提供对磁盘设备的字符、块方式访问。每个磁盘有两个设备文件名: 一个在/d…

Error0---local variable S is accessed from within inner class; needs to be declared final

local variable S is accessed from within inner class; needs to be declared final在内部类当中不能引用本地变量s,需要被声明为常量转载于:https://www.cnblogs.com/Cherrylalala/p/6636642.html

android版本如何修改时间,如何修改Android系统默认时间

相信很多人看到过Android手机或平板显示XXXX-01-01这个奇怪的日期&#xff0c;没错&#xff0c;这就是Android设备的默认日期。当Android设备没有联网&#xff0c;无法获取当前真实时间的时候&#xff0c;就会使用系统默认时间。大部分时候&#xff0c;系统默认时间是Epoch时间…

Java Web应用程序的反跨站点脚本(XSS)过滤器

这是为Java Web应用程序编写的一个好简单的反跨站点脚本&#xff08;XSS&#xff09;过滤器。 它的主要作用是从请求参数中删除所有可疑字符串&#xff0c;然后将其返回给应用程序。 这是我以前关于该主题的帖子的改进。 您应该将其配置为链&#xff08;web.xml&#xff09;中的…

生成建表脚本up_CreateTable

已经很久没用使用这个脚本了&#xff0c;今天用到&#xff0c;并做修改&#xff0c;增加了生成扩展属性功能。 Go if object_ID([up_CreateTable]) is not nullDrop Procedure [up_CreateTable] Go /* 生成建表脚本(V4.0) Andy 2017-3-28 */ Create Proc up_CreateTable (obje…

android程序员周记,程序员实习周记100篇

程序员实习周记100篇有效防止雷同&#xff01;简单修改即可使用&#xff01;姓名&#xff1a;XXX学号&#xff1a;20190920008专业&#xff1a;M]指导老师&#xff1a;实习时间&#xff1a;20XX-XX-XX—20XX-XX-XX2019年XX月XX日t8in6Ay8Cw7c HuktN6ttTE12V7A eZu9g e7W1Y Dxqx…

Python之装饰器

装饰器功能有两点&#xff1a;1.首先自动执行装饰器后面跟的这个函数&#xff0c;并将装饰器修饰的那个函数名作为参数带入装饰器后面函数&#xff1b;2.将装饰器后面函数的返回值&#xff0c;赋值给装饰器所修饰的那个函数。举个例子说明&#xff1a; 1 def outer(func):2 …

在独立Java应用程序中使用Tomcat JDBC连接池

这是从我们的客人文章W4G伙伴克拉伦斯豪的作者临春3从A按。 您可能会在文章结尾找到本书的折扣券代码&#xff0c;仅适用于Java Code Geeks的读者&#xff01; 请享用&#xff01; 在需要数据访问权限的独立Java应用程序中使用JDBC连接池时&#xff0c;大多数开发人员将使用com…

Python之路【目录】 2

http://www.cnblogs.com/wupeiqi/articles/4938499.html转载于:https://www.cnblogs.com/cp-miao/p/5750211.html

vs2019 缺android sdk,VS2019由于缺少NuGet Microsoft.NET.Sdk.Functions程序包而无法加载项目,但也无法添加此程序包(示例代码)...

我在解决方案中拥有的一个项目未在VSE2019中加载。它将引发此错误&#xff1a;C:MyProgramsrcMyProgram.Functions.csproj : error : The project file cannot be opened by the project system, because it is missing some critical imports or the referenced SDK cannot be…

数据库事物操作

事务 什么是事务?转账&#xff1a;1. 给wc账户减1000元2. 给wcxf账户加1000元 当给wc账户减1000元后&#xff0c;抛出了异常&#xff01;这会怎么样呢&#xff1f;我相信从此之后&#xff0c;wc再也不敢转账了。 使用事务就可以处理这一问题&#xff1a;把多个对数据库的操作绑…

通过OpenShift超越云技术

您是否厌倦了为您的应用程序请求新的开发机器&#xff1f; 您是否为应用程序设置新的测试环境感到烦恼&#xff1f; 您是否只想专注于和平开发应用程序而不会一直“沉迷于堆栈”&#xff1f; 我们听到你的声音。 我们也去过那里。 不用担心&#xff0c;OpenShift就在这里&#…

android+4.4+稳定性,新系统新UI!台电A10h四核安卓4.4.2性能测试

国内著名商标&#xff0c;数码用户首选品牌的台电科技在12月20日全国首发了安卓4.4.2系统&#xff0c;并且运行台电全新tUI同时&#xff0c;支持从安卓4.2系统OTA一键升级至安卓4.4.2系统&#xff01;作为国内首款升级到目前全球最新的Android4.4.2系统之后&#xff0c;整体性能…

网络知识点小结

VMware虚拟机三种联网方法及原理一、Brigde——桥接&#xff1a;默认使用VMnet0 1、原理&#xff1a; Bridge 桥"就是一个主机&#xff0c;这个机器拥有两块网卡&#xff0c;分别处于两个局域网中&#xff0c;同时在"桥"上&#xff0c;运行着程序&#xff0c;让…

在JUnit中超越核心Hamcrest

在通过JUnit和Hamcrest改进对assertEquals的文章中&#xff0c;我介绍了将Hamcrest与JUnit一起使用 。 然后&#xff0c;我查看了JUnit的内置Hamcrest Core Matcher支持 。 在本文中&#xff0c;我将介绍如何将Hamcrest的非核心匹配器与JUnit一起应用。 这些非核心匹配器默认情…

4pics1word android,4 Pics 1 Word

4 Pics 1 Word是一款非常有意思的看图猜词游戏&#xff0c;这款游戏中会给我们四张图片&#xff0c;玩家需要通过图片给出的信息来猜出是哪个词&#xff0c;看西西的介绍你可能以为这是一款千篇一律的看图猜词游戏&#xff0c;不过这里猜的不是中文而是英语单词。4 Pics 1 Word…

页面内锚点定位及跳转方法总结

接着上一篇&#xff0c;其实是一个功能&#xff0c;本来感觉挺简单的一个问题&#xff0c;没想到遇到两个坎儿&#xff0c;无语。。。 上一篇是关于scroll事件绑定的问题&#xff0c;这一篇的问题是&#xff1a;点击锚点跳转到相应DIV的问题。 最简单的方法是锚点用<a>标…

基于android的水稻叶片特征测量系统,基于Android的水稻叶片特征参数测量系统

基于Android的水稻叶片特征参数测量系统路艳1&#xff0c;肖志勇2&#xff0c;3&#xff0c;杨红云2&#xff0c;3*&#xff0c;周琼1&#xff0c;孙玉婷1【摘要】摘要&#xff1a;【目的】提供基于Android的水稻叶片特征参数测量系统&#xff0c;为农学研究提供精准数据。【方…