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.0分

5 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论