n = int(input())
lst1 = list(map(int,input().split()))
lst2 = list(map(int, input().split()))
lst3 = list(map(int, input().split()))
max_a = 0
max_b = 0
max_c = 0
lst_a = []
for i in range(n):
a,b,c = lst1[i], lst2[i], lst3[i]
lst_a.append(a-b-c)
lst_a.sort(reverse = True)
# 前缀和优化(将时间复杂度降至O(n))
for i in range(1, n):
lst_a[i] += lst_a[i-1]
for i in range(n):
if lst_a[i] <= 0:
break
max_a = i
lst_b = []
for i in range(n):
a,b,c = lst1[i], lst2[i], lst3[i]
lst_b.append(b-a-c)
lst_b.sort(reverse = True)
for i in range(1, n):
lst_b[i] += lst_b[i-1]
for i in range(n):
if lst_b[i] <= 0:
break
max_b = i
lst_c = []
for i in range(n):
a,b,c = lst1[i], lst2[i], lst3[i]
lst_c.append(c-a-b)
lst_c.sort(reverse = True)
for i in range(1, n):
lst_c[i] += lst_c[i-1]
for i in range(n):
if lst_c[i] <= 0:
break
max_c = i
result = max(max_a,max_b,max_c)
if result == 0:
print(-1)
else:
print(result)
0.0分
5 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复