-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAssignment-8_python
101 lines (85 loc) · 4.73 KB
/
Assignment-8_python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
Here there be Dragons
(IOI Training Camp, 2012)
The kingdom is falling into ruin. People live in fear. Dragons pillage, kill, and just generally cause as much havoc as they possibly can.
The king has just sent out a royal decree:
To any man out there who is able to bring me the heads of K dragons, I shall bequeath a lordship–to him, his sons and his grandsons, till the end of time.
Having seen this royal decree, and knowing that you are capable of killing dragons thanks to your extensive medieval combat training,
you set out on a quest to hunt down the evil creatures. Being a busy kind of guy, you would like to complete your quest quickly and kill K dragons through the shortest route.
The kingdom is arranged in a grid with R rows, numbered 0 to R-1, and C columns, numbered 0 to C-1 You start your quest at the top left corner of the grid, (0,0).
The total number of dragons in the kingdom is D, of which you have to kill K. Dragons are very territorial in nature, so each row of the grid contains at most one dragon.
Also, since the kingdom is situated on a hill, you travel only downwards on the grid, though you may move left or right as you please.
You are told that no two dragons are on the same row of the grid. Also, no dragon is at position (0,0).
For example, suppose the grid has 5 rows and 5 columns with 3 dragons, of which you have to kill any 2. The three dragons are located at (1,4), (2,3) and (4,4), as shown below.
In this case, your shortest route is to take 7 steps and kill the dragons in row 1 and row 2. Killing any other combination of 2 dragons takes 8 steps,
so this is the minimum possible. Note that once you've killed K dragons, you don't incur any cost to return home. You just want to find how long it takes to do all the killing.
|0 |1 |2 |3 |4
__|__|__|__|__|___
0 | | | | |
1 | | | | | D
2 | | | | D|
3 | | | | |
4 | | | | | D
Solution hint
. Number the dragons 1,2,…,D in ascending order of rows. Let mindist(i,j) denote the minimum distance travelled when the jth dragon killed is dragon i. Recall the constraint that there is no dragon at (0,0). Use dynamic programming to compute mindist(i,j) for all values of i and j, then find the minimum among mindist(i,K) for all i ≥ K.
Input format
. Line 1 : Four space-separated integers, R, C, K and D.
. Lines 2 to D+1 : Each line has two-space separated integers r and c, the row and column of the corresponding dragon.
Output format
. A single integer, the minimum total distance travelled to kill K dragons.
Test Data:
. In all testcases, K ≤ D ≤ R, and, for each dragon position (r,c), 0 ≤ r < R, and 0 ≤ c < C.
. In all testcases, 1 ≤ K,D ≤ 300.
. In 60% of the testcases, 1 ≤ R,C ≤ 300. In the remaining testcases, 1 ≤ R,C ≤ 100000.
. No two dragons will be on the same row.
. No dragon will be at position (0,0).
Sample Input:
5 5 2 3
1 4
4 4
2 3
Sample Output:
7
Program:
import sys
input = sys.stdin.readline
first = list(map(int,input().split(" ")))
k = first[2]
d = first[3]
index = [[0,0]]
for i in range(d):
List_row = list(map(int,input().split(" ")))
index.append(List_row)
sorted_index = sorted(index,key= lambda x: (x[0],x[1]))
DISCT_STORE_find_Distance = dict()
DISCT_STORE_LIST_MIDDLE = dict()
def find_Distance(j1,j2):
global DISCT_STORE_find_Distance
X_move = abs((sorted_index[j1][0])-(sorted_index[j2][0]))
Y_move = abs((sorted_index[j1][1])-(sorted_index[j2][1]))
steps = X_move + Y_move
DISCT_STORE_find_Distance[(f"{j1},{j2}")] = steps
return DISCT_STORE_find_Distance[(f"{j1},{j2}")]
def LIST_MIDDLE(i,j):
global DISCT_STORE_find_Distance
global DISCT_STORE_LIST_MIDDLE
if i == 1:
return find_Distance(0,j)
else:
find_DistanceList = []
for x in range(i-1,j):
if (f"{i-1},{x}") in DISCT_STORE_LIST_MIDDLE:
if (f"{x},{j}") in DISCT_STORE_find_Distance:
find_DistanceList.append(DISCT_STORE_LIST_MIDDLE[f"{i-1},{x}"]+DISCT_STORE_find_Distance[f"{x},{j}"])
else:
find_DistanceList.append(DISCT_STORE_LIST_MIDDLE[f"{i-1},{x}"]+find_Distance(x,j))
else:
DISCT_STORE_LIST_MIDDLE[f"{i-1},{x}"] = LIST_MIDDLE(i-1,x)
if (f"{x},{j}") in DISCT_STORE_find_Distance:
find_DistanceList.append(DISCT_STORE_LIST_MIDDLE[f"{i-1},{x}"]+DISCT_STORE_find_Distance[f"{x},{j}"])
else:
find_DistanceList.append(DISCT_STORE_LIST_MIDDLE[f"{i-1},{x}"]+find_Distance(x,j))
return min(find_DistanceList)
ANSWER = []
for g in range((len(sorted_index)-1),k-1,-1):
ANSWER.append(LIST_MIDDLE(k,g))
print(min(ANSWER))