解题思路:
就是枚举加上一个二分
注意事项:
参考代码:
num=eval(input())
list1=list(map(int,input().split()))
list2=sorted(list1)
result=[]
# 求中间数
mid=(1+num)>>1
midNum=list2[mid-1]
# 求左右两边的数
left=list2.index(midNum)
right=list2[::-1].index(midNum)
# 等于中间数的个数
sum1=list2.count(midNum)
for i in list1:
if i>midNum:
result.append(0)
elif i==midNum:
if left>=right:
result.append(0)
else:
if left+sum1-1>=right:
result.append(midNum+1-i)
else:
result.append(list2[mid]-i)
else:
if left-1>=right:
result.append(midNum-i)
else:
if left-1+sum1>=right:
result.append(midNum+1-i)
else:
result.append(list2[mid]-i)
# 得到结果
result=list(map(str,result))
print(" ".join(result))
0.0分
2 人评分
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:683 |
蓝桥杯历届试题-九宫重排 (C++代码)浏览:2783 |
C语言程序设计教程(第三版)课后习题9.8 (Java代码)浏览:1640 |
【绝对值排序】 (C语言代码)浏览:717 |
C语言程序设计教程(第三版)课后习题10.1 (Java代码)浏览:1447 |
A+B for Input-Output Practice (VII) (C++代码)浏览:615 |
小明A+B (C语言代码)浏览:1256 |
求圆的面积 (C语言代码)浏览:1270 |
C语言程序设计教程(第三版)课后习题1.6 (C语言代码)浏览:702 |
C语言程序设计教程(第三版)课后习题8.5 (C语言代码)浏览:936 |