山科交流赛-不水之题们

1.Foxes(传说是一个网络流,设置超级原点,超级汇点,删流加流,完全划水。。。)


Description

n只狐狸参加hardbird的派对,第i只狐狸的年龄是ai

1.每只狐狸都必须入座。

2.每张圆桌至少坐三只狐狸。

3.每两只相邻的狐狸的年龄相加必须为素数。

如果k只狐狸f1,f2…fk,那么对于1 ≤ ik - 1,fi 和fi + 1 是相邻的, f1 和 fk 也是相邻的。

现在如果我们给出n只狐狸的年龄,你能否告诉hardbird是否存在一种安排,在满足条件的前提下,让所有狐狸入座。



Input

测试样例有多组。

每组样例第一行为一个整数n (3 ≤ n ≤ 200),表示来参加派对的狐狸的数量。

每组样例第二行n个整数ai (2 ≤ ai ≤ 104)。

Output

如果存在一种安排让n只狐狸按要求入座,输出”Possible”,否则输出”Impossible”.

Sample Input

24
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
5
2 2 2 2 2

Sample Output

Possible
Impossible





2、恐怖袭击(spfa可做,多源最短路径,但可以设定超级原点超级终点转换为单源最短路径)

Description

A国是一个拥有n个城市的大国,B国正密谋对A国发动恐怖袭击,但在此之前需要打探A国的一些情报。于是B国的首脑派遣了s个恐怖分子潜入A国的不同城市,在此之前,B国已经在A国的t个不同的城市设立了情报交换站,用以将情报秘密送往本国。现已知该s个恐怖分子共享情报,他们想用最短的时间将情报送往t个交换站中的任意一个。你能帮他们计算所要走的最短路程吗?

Input

输入包含多组样例,每组样例首先包含四个正整数,城市的数量n(0<n<1000),城市中无向道路的条数m(0<m<1000000),恐怖分子的数量s(0<s<10),情报交换站的数量t(0<t<10),接下来会有m行,每行三个正整数,前两个为城市的标号u、v(1<=u,v<=n && u != v),第三个为他们之间的距离d(0<d<100)。相邻两城市之间可能有多条道路。接下来一行有s个正整数,代表当前恐怖分子所藏匿的城市标号,紧接着一行有t个正整数,代表情报交换站所在的城市标号。注意在s和t中出现的城市标号不重叠。输入以0 0 0 0结束。

Output

如果恐怖分子可以将情报送出,输出要走的最短路程。否则,输出"What a pity!"(不包含引号)。

Sample Input

6 1 3 3
4 5 1
1 2 3
4 5 6

6 2 2 4
1 3 3
2 4 4
1 2
3 4 5 6

0 0 0 0

Sample Output

What a pity!
3



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值