题目描述
给定一个数组,编写一个函数来计算它的最大N个数与最小N个数的和。你需要对数组进行去重。
说明:
数组中数字范围[0, 1000]
最大N个数与最小N个数不能有重叠,如有重叠,输入非法返回-1
输入非法返回-1
输入描述
第一行输入M, M标识数组大小
第二行输入M个数,标识数组内容
第三行输入N,N表达需要计算的最大、最小N个数
输出描述
输出最大N个数与最小N个数的和
用例1
输入
5
95 88 83 64 100
2
输出
342
说明
最大2个数[100,95],最小2个数[83,64], 输出为342。
用例2
输入
5
3 2 3 4 2
2
输出
-1
说明
最大2个数[4,3],最小2个数[3,2], 有重叠输出为-1。
def resort(num_list,N):
new_list=[]
for i in num_list:
if i not in new_list and i>=0 and i<=1000:
new_list.append(i)
new_list.sort()
if len(new_list)//2<N or N<1:
return -1
else:
sum=0
for i in range(N):
sum+=(new_list[i]+new_list[len(new_list)-i-1])
return sum
M=int(input())
num_list=list(map(int,input().split()))
N=int(input())
Sum=resort(num_list,N)
print(Sum)