文章

1

粉丝

70

获赞

1

访问

4.6k

头像
python
P1536 清华大学2019年机试题
发布于2022年3月22日 12:02
阅读数 4.6k

from collections import defaultdict
import heapq
n,m=map(int,input().split())
a=list(map(int,input().split()))
E = defaultdict(list)
Eprev = defaultdict(list)
cnt = defaultdict(int)
out = defaultdict(int)
for _ in range(m):
	u,v = map(int, input().split())
	E[u].append(v)
	Eprev[v].append(u)
	cnt[v]+=1
	out[u]+=1
ans = 0
count = 0
f = [0]*n #最早结束时间
q = []
for i in range(1,1+n):
	if cnt[i]==0:
		q.append((a[i-1], i))  # 最早结束时间,i
heapq.heapify(q)
while q:
	cur_time, node = heapq.heappop(q)
	f[node-1] = cur_time
	ans = max(ans, cur_time)
	for nxt in E[node]:
		cnt[nxt]-=1
		if cnt[nxt]==0:
			heapq.heappush(q, (cur_time+a[nxt-1], nxt))
print(ans)
idx = []
g = [ans]*n # 最晚结束时间
q = []
for i in range(n):
	if out[i+1]==0: # 后继没点了
		q.append(i+1)
while q:
	t = []
	for i in q:
		for prev in Eprev[i]:
			g[prev-1] = min(g[prev-1], g[i-1]-a[i-1])
			out[prev]-=1
			if out[prev]==0:
				t.append(prev)
	q = t
total = 1
mod = 10**9+7
for gi,fi i...
登录查看完整内容


登录后发布评论

暂无评论,来抢沙发