[Uva 10766]组织部门

成绩 开启时间 2014年09月19日 星期五 10:08
折扣 0.8 折扣时间 2014年09月26日 星期五 10:08
允许迟交 关闭时间 2014年09月26日 星期五 10:08
输入文件 organising.in 输出文件 organising.out

【题目描述】

我是一位不愿透露姓名的人事部主任,就职于一家中等规模的公司。现在我有一个小问题,因此需要一名有经验程序员的帮助。

目前,我们的公司被分成了一些或多或少独立的部门。为了使我们的业务更加高效,需要按照层次结构组织这些部门,表示哪些部门由其他部门掌管。例如,如果有四个部门A,B,C,D,我们可以将它们按照上图中的方法组织,其中A部门控制B和D部门,D部门控制C部门。

有一个部门是中央管理部(即图中的A部门),显然它必须在层次结构的顶端,但其余部门的相对重要性并未被确定,因此在上图中,C部门和D部门可以交换位置使得C部门掌管D部门。但是,让有些部门相互协作或许是不可能的,在这种情况下它们不能直接掌管对方。例如,如果上图中的A和D不能互相协作,那么图1的组织方式就是不合法的。

一般而言,总有许多种组织部门的方法,因此能够找到最佳方案(例如,让技术部掌管市场部并不是一个好的主意)。但这个任务对你而言太复杂了,你的任务仅仅是帮助我们计算应该给我们雇来寻找最佳组织方法的咨询顾问多少费用。为了计算这一费用,我们需要知道这个问题到底有多难,因此你需要计算出有多少种组织部门的不同方式。

对了,我需要在五小时之内得到答案。

【输入格式】

第一行有三个整数N,M,K(1<=N<=12,0<=M<=1500,1<=K<=N)。N代表部门数量,K代表中央管理部的编号。

接下来有M行,每行有两个整数1<=i,j<=N(i≠j),代表部门i和部门j无法协作(也就是说i无法掌管j,而j也无法掌管i)。

【输出格式】

输出组织部门的方案数。答案保证不超过64位有符号整数的范围。

【样例输入】

5 5 2

3 1

3 4

4 5

1 4

5 3

4 1 1

1 4

3 0 2

【样例输出】

3

8

3

【提示】

【来源】

Uva 10766 Organising the Organisation