您的位置:首页 > 其它

【算法------01】从某个数字列表中找出两个彼此最接近但不相等的数

2016-03-12 20:45 423 查看
最接近但不相等,即两者间的绝对差是最小的

python 

from random import randrange

seq = [randrange(10**10) for i in range(100)]

dd = float('inf')

for x in seq:

for y in seq:

if x == y :

continue

d = abs(x - y)

if d < dd:

xx, yy, dd = x, y ,d

print xx,yy

复杂度平方级

seq.sort()

dd = float('inf')

for i in range(len(seq) - 1):

x, y = seq[i], seq[i + 1]

if x == y :

continue

d = abs(x - y)

if d < dd:

xx, yy dd = x, y ,d

print xx,yy

排序通常是一个线性对数级操作,已排序的序列中最接近的两个数必然是相邻的
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: