JZOJ 2126~2129 题目

目录:

2126. 【GDOI2003】删边

Description

  连通图是指任意两个顶点都有路径可互相到达的图。
  读入一个无向的连通图,输出最多能删掉多少条边,使这个图仍然连通。

Input

  第一行为图的顶点数N(1<=N<=100)和边数M,用一个空格隔开,图中的顶点用1到N的整数)编号。接下来的M行,每行用两个数V1,V2表示一条边。V1,V2用一个空格隔开,表示这条边所连接的顶点的编号(V1<>V2),同一条边不会重复出现。

Output

  输出最多能删掉的边数。

Sample Input

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

Sample Output

3


2127. 【GDOI2003】骑士问题

Description

  在一个标准8*8的国际象棋棋盘上,棋盘中有些格子可能是有障碍物的。已知骑士的初始位置和目标位置,你的任务是计算骑士最少需要多少步可以从初始位置到达目标位置。有障碍物的格子当然不可以到达。
  标准的8*8的国际象棋中每一个格子可以用唯一的编号确定。行用1-8这8个数字依次表示,列用’a’-’h’这8个字母依次表示。例如左下图的骑士所在位置(图中有n的格子)的编号为“d4”(注意‘d’和‘4’之间没有空格)。   
  我们知道国际象棋中的骑士可以按“L”路线移动(一个方向走2个格子,接着垂直方向走1个格子)。因此,如左上图中的骑士(位于d4),可以到达位置c2,b3,b5,c6,e6,f5,f3,e2(图中有‘x’标记的格子)。此外,骑士不能够移出棋盘。
  骑士可以按照移动规则自由地在棋盘上没有障碍物的格子中移动。右上图给出了一个骑士移动的例子。初始格子用‘n’标记,目标格子用‘N’标记,有障碍物的格子用‘b’标记。一个可行的移动序列在图中用数字标记出来。(a1,b3,a5,c6,e5,g4,h2,f1)。总共需要7步才能完成。事实上,这也就是最小的步数了。
这里写图片描述
Input

  输入文件包括1个或多个测试数据。
  每一个测试数据的第一行是一个整数b(-1<=b<=62),表示棋盘中有障碍物的格子数目,当b=-1时,输入文件结束。
  第二行含b个不同的障碍物的格子编号,用空格隔开。当b=0时,此行为空行。
  第三行是骑士的初始格子和目标格子的编号,也是用空格隔开。初始格子和目标格子是不同的,且都没有障碍物。

Output

  对于每个数据,输出一行。格式:Board n: m moves,其中n表示数据的序号(从1开始)m表示骑士所用的最小的步数。
  如果骑士无法到达目标格子,输出:Board n: not reachable

Sample Input

10
c1 d1 d5 c2 c3 c4 d2 d3 d4 c5
a1 f1
0

c1 b3
2
b3 c2
a1 b2
-1

Sample Output

Board 1: 7 moves
Board 2: 1 moves
Board 3: not reachable


2128. 【GDOI2003】排列的编码

Description

  对于n个元素的排列P=(p1,p2,……,pn),请你编写一个程序,在不构造出所有排列的情况下,直接输出该排列在按字典序排列的字典中的序数d(p),其中p1∈{1,2,3,…,n},1<=n<=50。例如:n=4,若p=(2,3,4,1),则d(p)=10;若p=(4,2,1,3),则d(p)=21

Input

  每一行对应一个数据,格式为(n,(p1,p2,….,pn))其中n表示排列的元素个数,(p1,p2,…pn)就是这n个元素的某个排列。文件的最后一行只包含“-1”,表示输入文件结束。

Output

  对于每个数据,输出对应的d(p)。所有数据的结果都输出到一行中,用逗号分开。

Sample Input

(4,(3,2,1,4))
(5,(3,5,1,2,4))
-1

Sample Output

15,67


2129. 【GDOI2003】求值

Description

  给出N个整数X1,X2,X3,…,Xn,将这N个数从小到大排序为:A1,A2,A3,…,An,记数列A1,A2,A3,…,An的奇数项的和为P,偶数项之和为Q,令T=|P-Q|,计算T的值。

Input

  输入文件的第一行为整数N(1<=N<=50000)。
  接下来的N行每行有一个整数,按顺序给出X1,X2,X3,。。。Xn的值(|Xi|<=1000)

Output

  输出整数T的值。

Sample Input

3
1
3
2

Sample Output

2

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值