蚂蚁的笔试题目

面试了某蚂蚁,笔试题目,没有编译器,直接白板写代码,够溜的,用了暴力破解,有点问题,没有达到最优

 

题目:给你一个数组和一个数字num,找出数组中两个数a 和b,使得a+b 与 num 的差的绝对值最小。比如输入[8,3,6,1] 和13,输出8 和6。

 

输入的代码:

array1,num1=input().split(" ")

array=[]
array=array1[1:-1].split(",")
array=list(map(int,array))

num=int(num1)


print(array)
print(num)

 

解决问题的部分,主要思路是:先把array排序,用两个指针,一个在左边,一个在右边,两个指针所指的数字之和,如果大于13,那么j--   如果小于13,那么i++

这样的话,就可以比暴力破解更快

array.sort()
length=len(array)
i=0
j=length-1
deta=0
temp_min=num
while i<j-1:
    temp_sum=array[i]+array[j]
    deta=abs(temp_sum-num)
    if deta<temp_min:
        temp_min=deta
        index_i=i
        index_j=j
        i+=1
    if deta>temp_min:
        j-=1
print(array[i],array[j])

 

转载于:https://www.cnblogs.com/captain-dl/p/10576819.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值