阿里春招实习生笔试3.19第一题

阿里春招实习生笔试3.19第一题

  1. n个人参加一个促销活动,每个人手里有个数字啊 a[i],如果某个人手里的数字是平方数(4,9,16…),则他中奖!
  2. 现有一种修改券,可以让人们手中的数字 +1 或者 -1,每个人可以用多张修改券。
  3. 想要保证n/2的人中奖,最少要准备多少张修改券?
  4. 题目测试集保证 n 为偶数。

python解法

import math

n = int(input())
lst = list(map(int,input().split()))
lst_1 = lst[:]
a,c,f= [0]*n,[0]*n,[0]*n

for i in range(n):
	ab = (math.sqrt(lst[i]))%1
	while ab != 0.0:
		lst[i] += 1
		ab = (math.sqrt(lst[i]))%1
		a[i] += 1

for i in range(n):
	b = (math.sqrt(lst_1[i]))%1
	while b != 0.0:
		lst_1[i] -= 1
		b = (math.sqrt(lst_1[i]))%1
		c[i] += 1

for i in range(n):
	f[i] = min(a[i],c[i])

f.sort()
x = int(n//2)
sum = 0
for i in range(x):
	sum += f[i]
print(sum)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值