首页 > 解决方案 > 比较两个列表中的值并从第三个列表中返回相似或最接近的值

问题描述

我想在 v 中找到 j 的相似值并返回 x。当 j 中的值不等于 v 时,我会喜欢检测 v 中 j 值之间的 2 值的代码。所以如果 j 介于 v1 和 v2 之间,我希望代码返回max(x1,x2)- ( ((j-v1)/(v2-v1))*(max(x1,x2)-min(x1,x2)))

v= [100,200,300,400,500,600,700,800,900,1000,1100]
x= [67,56,89,21,90,54,38,93,46,17,75]
j= [200,300,400,460,500,600,700,800,870,900,950]

for i in range(len(v)-1):
    if v[i] > j and V[i+1] < j:
        p = max(x[i],x[i+1])- ( ((j-v[i])/(v[i+1]-v[i]))*(max(x[i],x[i+1])-min(x[i],x[i+1])))
    elif v[i] ==j:
        b= x[i]
print(p,b)

"""
n = [x[i] for i, v_ele in enumerate(v) if v_ele in j]
p=  [x[i] for i, v_ele in enumerate(v) if v_ele > j and v_ele 
print(n)
"""

我会喜欢我的答案

[56,89,21,48.6,90,54,38,93,60.1,46,31.5]

标签: pythonlistfor-loopif-statementmath

解决方案


我们可以使用以下两个辅助函数来做到这一点。请注意,我认为问题中您的预期输出中的第四个元素可能存在轻微错误 - 我得到了那个值,62.4而你有48.6.

代码:

def get_v_indx(j_ele, v):
    if j_ele in v:
        return v.index(j_ele)
    else:
        for i, ele in enumerate(v):
            if ele > j_ele:
                return i-1+(j_ele-v[i-1])/(ele-v[i-1])

def get_x_ele(i, x):
    try:
        return x[i]
    except TypeError:
        return x[int(i)] + (x[int(i)+1]-x[int(i)])*(i-int(i))

用法:

>>> [get_x_ele(get_v_indx(j_ele, v), x) for j_ele in j]
[56, 89, 21, 62.4, 90, 54, 38, 93, 60.1, 46, 31.5]

推荐阅读