-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathbilingual.py
64 lines (56 loc) · 1.78 KB
/
bilingual.py
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
# Copyright (c) 2015 kamyu. All rights reserved.
#
# Google Code Jam 2015 Round 2 - Problem C. Bilingual
# https://code.google.com/codejam/contest/8234486/dashboard#s=p2
#
# Time : O((N * L)^2)
# Space : O(N * L)
#
def dfs(node, sink, used, E):
if used[node]:
return False
used[node] = True
for i in xrange(len(E[node])):
if E[node][i] == sink or dfs(E[node][i], sink, used, E):
E[E[node][i]].append(node)
E[node][-1], E[node][i] = E[node][i], E[node][-1]
E[node].pop()
return True
return False
def bilingual():
N = input()
def word_id(word_ids, word):
if word in word_ids:
return word_ids[word]
word_ids[word] = len(word_ids)
return word_ids[word]
# Parse lines.
word_ids = {}
lines = [list(set([word_id(word_ids, word) \
for word in raw_input().strip().split()])) \
for _ in xrange(N)]
# Init edges.
# i (0 ~ N) node represents the ith line.
# 2 * i + N node represents the word i is in English.
# 2 * i + N + 1 node represents the word i is in French.
source, sink = 0, 1
E = [[] for _ in xrange(2 * len(word_ids) + N)]
for i in xrange(len(word_ids)):
E[2 * i + N].append(2 * i + N + 1)
for x in lines[0]:
E[source].append(2 * x + N)
for y in lines[1]:
E[2 * y + N + 1].append(sink)
for i in xrange(2, N):
for x in lines[i]:
E[2 * x + N + 1].append(i)
E[i].append(2 * x + N)
# Run max flow.
flow = 0
used = [False for _ in xrange(len(E))]
while dfs(source, sink, used, E):
flow += 1
used = [False for _ in xrange(len(E))]
return flow
for case in xrange(input()):
print "Case #%d: %d" % (case + 1, bilingual())