Tải bản đầy đủ (.pdf) (17 trang)

150 bài toán tin Trạm nghỉ

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (240.09 KB, 17 trang )



149

139. TRẠM NGHỈ
M

t toán k

s
ĩ
b

ng

a
đ
i thám hi

m m

t khu r

ng và
đế
n khi tr

i t

i, h


mu

n
đ
i v

nh

ng tr

m
ngh

. R

t may là các k

s
ĩ

đề
u có b

n
đồ
khu r

ng trong tay, nh



đ
ó có th

xác
đị
nh chính xác v

trí
c

a h

, các tr

m ngh

, các khu v

c có thú d

và t

t nhiên c

v

trí c

a các con ng


a (n
ơ
i h


đ
ã b


l

i).
M

i k

s
ĩ
s

ph

i ch

n cho mình m

t con ng

a, m


t tr

m ngh

và dùng còi siêu âm g

i con ng

a
đ
ó
v

tr

m ngh


đ
ã ch

n. M

i tr

m ngh

ch



đủ
ch

cho m

t k

s
ĩ
và m

t con ng

a.
Giả sử rằng có m trạm nghỉ, n kỵ sĩ, n con ngựa và bạn là một trong số những kỵ sĩ đó. Hãy vạch
ra hành trình cho các kỵ sĩ và các con ngựa để thời gian tính từ lúc bắt đầu cho tới khi tất cả các
con ngựa và các kỵ sĩ về tới trạm nghỉ tương ứng là nhỏ nhất.
B

n
đồ
khu r

ng
đượ
c mã hoá b

ng m

t l

ướ
i ô vuông
đơ
n v

kích th
ướ
c pxq. Trên m

i ô ghi m

t
trong 5 ký hi

u:


"%":
Đị
a
đ
i

m có thú d




".":
Đị

a
đ
i

m an toàn (không có thú d

)


"&":
Đị
a
đ
i

m an toàn có m

t con ng

a
đ
ang
đứ
ng


"*":
Đị
a
đ

i

m an toàn có m

t k

s
ĩ

đ
ang
đứ
ng


"@": Tr

m ngh


V

i 1
đơ
n v

th

i gian, m


i k

s
ĩ
và m

i con ng

a có th

th

c hi

n m

t b
ướ
c
đ
i. Nhìn trên b

n
đồ
,
m

i b
ướ
c

đ
i c

a m

t k

s
ĩ
là m

t phép di chuy

n t

ô
đ
ang
đứ
ng sang m

t trong các ô k

c

nh,
b
ướ
c
đ

i này
đượ
c mã hoá b

ng m

t trong 4 ký hi

u {E, W, S, N}. M

i b
ướ
c
đ
i c

a m

t con ng

a là
m

t phép di chuy

n nh
ư
m

t n

ướ
c
đ
i c

a quân mã theo lu

t c

, b
ướ
c
đ
i này
đượ
c mã hoá b

ng m

t
trong 8 ký hi

u {1, 2, 3, 4, 5, 6, 7, 8}. Các k

s
ĩ
c
ũ
ng nh
ư

các con ng

a không
đượ
c
đ
i t

i ô có thú
d

hay
đ
i ra ngoài b

n
đồ
. Các ký hi

u t
ươ
ng

ng v

i các h
ướ
ng
đ
i

đượ
c ch

ra trong hình d
ướ
i
đ
ây:

6 7
N 5 8
W * E &
S 4 1
3 2

Dữ liệu:
Vào t

file v
ă
n b

n HORSEMAN.INP


Dòng
đầ
u tiên: Ch

a hai s


p, q cách nhau 1 d

u cách


p dòng ti
ế
p theo, dòng th

i ch

a q ký t

, ký t

th

j là ký hi

u ghi trên ô (i, j) c

a b

n
đồ

Kết quả:
Ghi ra file v
ă

n b

n HORSEMAN.OUT


Dòng
đầ
u tiên: Ghi th

i gian nhanh nh

t
để
t

t c

các k

s
ĩ
và các con ng

a v

t

i tr

m ngh



t
ươ
ng

ng


2n dòng ti
ế
p theo, c

hai dòng ghi hành trình c

a m

t k

s
ĩ
:


Dòng 1: Ghi hai s

x, y cách nhau m

t d


u cách là v

trí ô (x, y) c

a m

t k

s
ĩ



Dòng 2: Ghi m

t dãy ký t

t
ượ
ng tr
ư
ng cho m

t dãy các b
ướ
c
đ
i c

a k


s
ĩ
t

ô (x, y) theo
đ
úng th

t

này
đế
n m

t tr

m ngh

.


2n dòng ti
ế
p theo, c

hai dòng ghi hành trình c

a m


t con ng

a:


Dòng 1: Ghi hai s

u, v cách nhau m

t d

u cách là v

trí ô (u, v) c

a m

t con ng

a


Dòng 2: Ghi m

t dãy ký t

t
ượ
ng tr
ư

ng cho m

t dãy các b
ướ
c
đ
i c

a con ng

a t

ô (u, v)
theo
đ
úng th

t

này
đế
n m

t tr

m ngh

.
Ràng buộc:



5 ≤ p, q ≤ 100


1 ≤ n = s

ô "&" = s

ô "*" ≤ 100


n ≤ m = s

ô "@" ≤ 100


Luôn luôn có ph
ươ
ng án th

c hi

n yêu c

u c

a
đề
bài




150

Ví dụ:
( Kết quả file Output này sai ! ) Đáp án tối ưu phải là 3 mới đúng !

HORSEMAN.INP HORSEMAN.OUT
5 6
.&&.*.
.%%...
@@.@.@
&.....
*...*.

4
1 5
SSW
5 1
NN
5 5
NNE
1 2
3
1 3
2
4 1
1727





151

140. CHIA CÂN BẰNG
Xét
đồ
th

vô h
ướ
ng liên thông G = (V, E) có n
đỉ
nh và m c

nh, các
đỉ
nh
đượ
c
đ
ánh s

t

1 t

i n

Hãy bỏ đi một số ít nhất các cạnh của đồ thị sao cho:

1.
Đồ
th

còn l

i có
đ
úng 2 thành ph

n liên thông
2.
Đỉ
nh 1 và
đỉ
nh n không thu

c cùng m

t thành ph

n liên thông
3.

Trong các ph
ươ
ng án tho

mãn c


hai
đ
i

u ki

n trên, hãy ch

ra ph
ươ
ng án mà
độ
chênh l

ch v


s


đỉ
nh gi

a hai thành ph

n liên thông
đ
ó là nh

nh


t

Dữ liệu:
Vào t

file v
ă
n b

n BALANCE.INP


Dòng 1: Ch

a hai s

n, m (2 ≤ n ≤ 300)


m dòng ti
ế
p theo, m

i dòng ch

a hai s

u, v t
ươ

ng

ng v

i m

t c

nh (u, v) c

a
đồ
th



Kết quả:
Ghi ra file v
ă
n b

n BALANCE.OUT


Dòng 1: Ghi s

c

nh
đượ

c b

(k)


k dòng ti
ế
p theo, m

i dòng ghi hai
đỉ
nh t
ươ
ng

ng v

i m

t c

nh
đượ
c b



Ví dụ:
BALANCE.INP BALANCE.OUT





152

141. LĂN XÚC XẮC
Cho m

t l
ướ
i ô vuông
đơ
n v

kích th
ướ
c mxn, trên m

i ô ghi m

t s

t

nhiên ≤ 7. Có m

t con súc
s

c (hình l


p ph
ươ
ng c

nh 1
đơ
n v

) n

m t

i m

t ô (x, y) mang s

7. Các m

t con súc s

c
đượ
c ghi
các s

nguyên d
ươ
ng t


1
đế
n 6: m

t trên mang s

1, m

t bên h
ướ
ng v

mép trên c

a l
ướ
i mang s


2, m

t bên h
ướ
ng v

mép trái c

a l
ướ
i mang s


3, t

ng hai s

ghi trên hai m

t
đố
i di

n b

t k

luôn
b

ng 7. (Xem hình v

)

1
2
3
1
2
3
4
3

4
1
6 6 6 6
3 4 1 2

Cho phép l
ă
n con súc s

c sang m

t trong 4 ô k

c

nh. Sau m

i phép l
ă
n nh
ư
v

y, m

t trên c

a súc
s


c s

tr

thành m

t bên t
ươ
ng

ng v

i h
ướ
ng di chuy

n và m

t bên theo h
ướ
ng di chuy

n s

tr


thành m

t

đ
áy. M

t phép l
ă
n
đượ
c g

i là h

p l

n
ế
u nó luôn
đả
m b

o s

ghi

ô súc s

c
đ
ang
đứ
ng

ho

c b

ng 7, ho

c b

ng v

i s

ghi

m

t
đ
áy c

a súc s

c. Nh
ư
ví d

trên, ta có th

l
ă

n lên trên, sang
ph

i hay sang trái nh
ư
ng không th

l
ă
n xu

ng d
ướ
i.

Yêu cầu:
Hãy chỉ ra một số hữu hạn các phép lăn hợp lệ để lăn con súc sắc ra một ô biên của lưới, nếu có
nhiều phương án thực hiện thì chỉ ra phương án mà tổng các số ghi ở mặt trên của súc sắc sau
mỗi bước di chuyển là cực tiểu.

Dữ liệu:
Vào t

file v
ă
n b

n ROLL.INP



Dòng 1: Ch

a 4 s

m, n, x, y (1 < x < m ≤ 300; 1 < y < n ≤ 300)


m dòng ti
ế
p theo, dòng th

i ch

a n s

mà s

th

j là s

ghi t

i ô (i, j) c

a l
ướ
i

Kết quả:

Ghi ra file v
ă
n b

n ROLL.OUT
G

m m

t dòng ch

a dãy liên ti
ế
p các ký t

, ký t

th

k có th

là L, R, U ho

c D t
ươ
ng

ng v

i

phép l
ă
n t

i b
ướ
c th

k là l
ă
n sang trái, l
ă
n sang ph

i, l
ă
n lên trên hay l
ă
n xu

ng d
ướ
i.

Ví dụ

ROLL.INP ROLL.OUT
9 6 3 3
0 0 0 0 0 0
0 0 2 4 0 0

1 4 7 6 6 6
0 0 2 3 0 0
0 0 0 1 0 0
0 0 0 4 0 0
0 0 0 6 0 0
0 0 0 3 0 0
0 0 0 1 0 0

URDDLULL




153

142. CHUYỂN HÀNG
B

n
đồ
m

t kho hàng hình ch

nh

t kích th
ướ
c mxn
đượ

c chia thành các ô vuông
đơ
n v

(m hàng, n
c

t: các hàng
đ
ánh s

t

trên xu

ng d
ướ
i, các c

t
đ
ánh s

t

trái qua ph

i). Trên các ô c

a b


n
đồ

m

t s

ký hi

u:


Các ký hi

u #
đ
ánh d

u các ô
đ
ã có m

t ki

n hàng x
ế
p s

n,



M

t ký hi

u *:
Đ
ánh d

u ô
đ
ang có m

t rô b

t


M

t ký hi

u $:
Đ
ánh d

u ô ch

a ki


n hàng c

n x
ế
p


M

t ký hi

u @:
Đ
ánh d

u v

trí ô mà c

n ph

i x
ế
p ki

n hàng B vào ô
đ
ó



Các ký hi

u d

u ch

m ".": Cho bi
ế
t ô
đ
ó tr

ng
T

i m

t th

i
đ
i

m, rô b

t có th

th


c hi

n m

t trong 6
độ
ng tác ký hi

u là:


L, R, U, D: T
ươ
ng

ng v

i phép di chuy

n c

a rô b

t trên b

n
đồ
: sang trái, sang ph

i, lên trên,

xu

ng d
ướ
i. Th

c hi

n m

t phép di chuy

n m

t 1 công


+, -: Ch


đượ
c th

c hi

n khi rô b

t
đứ
ng


ô bên c

nh ki

n hàng $. Khi th

c hi

n thao tác +, rô
b

t
đứ
ng yên và
đN
y ki

n hàng $ làm ki

n hàng này tr
ượ
t theo h
ướ
ng
đN
y,
đế
n khi ch


m m

t
ki

n hàng khác ho

c t
ườ
ng nhà kho thì d

ng l

i. Khi th

c hi

n thao tác -, rô b

t kéo ki

n hàng $
v

phía mình và lùi l

i 1 ô theo h
ướ
ng kéo. Th


c hi

n thao tác
đN
y ho

c kéo m

t C công
Lu

t: Rô b

t ch


đượ
c di chuy

n vào ô không ch

a hàng c

a kho.

Hãy tìm cách hướng dẫn rô bốt thực hiện các thao tác để đưa kiện hàng $ về vị trí @ sao cho số
công phải dùng là ít nhất

Dữ liệu:
Vào t


file v
ă
n b

n CARGO.INP


Dòng 1: Ghi ba s

nguyên d
ươ
ng m, n, C (m, n ≤ 100; c ≤ 100)


m dòng ti
ế
p theo, dòng th

i ghi
đủ
n ký hi

u trên hàng th

i c

a b

n

đồ
theo
đ
úng th

t

t

trái
qua ph

i. Các ký hi

u
đượ
c ghi li

n nhau
Kết quả
: Ghi ra file v
ă
n b

n CARGO.OUT


Dòng 1: Ghi s

công c


n th

c hi

n


Dòng 2: M

t dãy liên ti
ế
p các ký t

∈ {L, R, U, D, +, -} th

hi

n dãy các
độ
ng tác c

n th

c hi

n
c

a Rô b


t
Ràng buộc:
Luôn có ph
ươ
ng án th

c hi

n yêu c

u
đề
bài

Ví dụ:

CARGO.INP CARGO.OUT CARGO.INP CARGO.OUT
6 8 3
###..###
*$....##
####.###
####..##
#@....##
########

23
+RRRR-UR+DDDRD+

10 10 2

.........#
.####.#.##
*$.......#
#######.##
#######...
#######.#.
#@........
#######.##
##########
##########

34
+RRRRRRR-LUURRD+DDDDD-URRDDL+




154

143. GHÉT NHAU NÉM ĐÁ...
Liz và Lilly
đ
ã t

ng là nh

ng ng
ườ
i b


n r

t thân, nh
ư
ng h


đ
ã cãi l

n và quy
ế
t
đị
nh chia tay nhau.
"Tôi không mu

n nhìn th

y b

n n

a, tôi s


đặ
t nh

ng t


ng
đ
á


đ
âu
đ
ó
để
n
ế
u tôi có
đ
i
đ
âu t

nhà,
tôi c
ũ
ng không bao gi

ph

i nhìn th

y cái b


n m

t c

a b

n" - C

hai
đề
u nói.
L&L cùng s

ng trong m

t ngôi làng nh


đượ
c chia thành l
ướ
i ô vuông
n
x
n
. Nhà c

a Liz

ô (1, 1)

và nhà Lilly

ô (n, n). M

i ô c

a l
ướ
i mang m

t trong 3 ký hi

u:


".": Vùng
đấ
t (Land)


"X": H

(Lake)


"*": T

ng
đ
á (Rock)

M

i ng
ườ
i có th

di chuy

n t

m

t ô sang ô k

c

nh n
ế
u
đ
ó là vùng
đấ
t, và khi
đứ
ng

m

t ô (x, y),
h


có th

nhìn th

y ô (x', y') n
ế
u:


Ô (x', y') là cùng hàng ho

c cùng c

t v

i ô (x, y)


Kho

ng cách t

ô (x, y)
đế
n ô (x', y') không quá
k




Không có t

ng
đ
á nào ch

n t

m m

t
C

hai
đề
u là k

l
ườ
i bi
ế
ng, vì v

y h

ch

mu

n

đặ
t thêm m

t s

ít nh

t các t

ng
đ
á.
Đồ
ng th

i, các
t

ng
đ
á ph

i
đặ
t cách nhà c

a m

i ng
ườ

i m

t kho

ng cách t

i thi

u là
m.
Lưu ý: Khoảng cách giữa hai ô (x
1
, y
1
) và (x
2
, y
2
) quy ước là



x
1
- x
2



+




y
1
- y
2





Hãy chỉ ra cách đặt các tảng đá thoả mãn yêu cầu của cả hai người

Dữ liệu:
Vào t

file v
ă
n b

n FAREWELL.INP


Dòng 1: Ch

a 3 s

n, k, m (5 ≤ n ≤ 20; 1 ≤ k, m ≤ n) cách nhau
đ

úng 1 d

u cách


n dòng ti
ế
p theo, dòng th

i ch

a n ký t

liên ti
ế
p mà ký t

th

j là ký hi

u ô (i, j) c

a l
ướ
i

Kết quả:
Ghi ra file v
ă

n b

n FAREWELL.OUT


Dòng 1: Ghi s

t

ng
đ
á ph

i
đặ
t, trong tr
ườ
ng h

p không có ph
ươ
ng án thì dòng này ghi s

-1


Trong tr
ườ
ng h


p có ph
ươ
ng án kh

thi thì n dòng ti
ế
p theo, dòng th

i ghi n ký t

liên ti
ế
p mà
ký t

th

j là ký hi

u ô (i, j) c

a l
ướ
i sau khi
đ
ã
đặ
t
đ
á. L

ư
u ý r

ng ta v

n dùng ký hi

u * cho
nh

ng t

ng
đ
á
đ
ã có và dùng ký hi

u "#" cho nh

ng t

ng
đ
á
đặ
t thêm

Ví dụ


FAREWELL.INP FAREWELL.OUT FAREWELL.INP FAREWELL.OUT
7 4 4
.......
......*
....*X.
**.*.X.
...*...
.XX..*.
.......
2
.......
.....#*
....*X.
**#*.X.
...*...
.XX..*.
.......
8 7 3
........
.XXXXXX.
.X....X.
.X....X.
.X....X.
.X....X.
.XXXXXX.
........
4
...#....
.XXXXXX.
.X....X.

#X....X.
.X....X#
.X....X.
.XXXXXX.
....#...

×