我有以下作为我的意见:
a10=[['p', 'e'], ['t', 'h','a'],['e', 'a'],['p','e'],['a']]
c10=[['p','e'],['e','h'],['e', 'a']]
a11=[4,5,2,1,3]
平均值以这种方式计算:
首先它应该检查c10
中是否存在['p','e']
的第一个元素,即a10
。如果它存在,那么它应该采取所有匹配的索引(这里索引0和3)。现在它应该转到' a11'中的那些指数位置。并计算均值,因此它将是(4+1)/2=2.5
如果没有完全匹配,例如c10
的第二个元素,即['e','h']
,那么它应该检查单个元素,'e'
和'h'
并搜索这些字符在a10
中存在的索引,这里的索引是:0,2,3(因为在这些位置' e'存在)和1(因为在这些位置&#39) ; h'存在)并在a11
中搜索这些索引并计算平均值。
所以average=(4+5+2+1)/4
因此, 我的输出应该是这样的:
average=2.5
#ie average=(4+1)/2
- 所以,如果存在完全匹配,则应该从' a11' ...中获取相应的元素并进行计算平均值。
average=3.0
#ie average=(4+5+2+1)/4
- 如果没有完全匹配,则应匹配列表列表中的各个元素,然后通过获取a11
中的值来计算均值。
average=2.0
#,, average=2
- 如果存在完全匹配,则应返回该值。
我写了以下代码:
a10=[['p', 'e'], ['t', 'h','e'],['e', 'a'],['p','e'],['a']]
c10=[['p','e'],['e','h'],['e', 'a']]
a11=[4,5,2,1,3]
max_=3
for i in range(len(a10)):
if len(a10[i])<3:
a10[i]=a10[i]+(3-len(a10[i]))*[str('')]
for i in range(len(c10)):
if len(c10[i])<3:
c10[i]=c10[i]+(3-len(c10[i]))*[str('')]
for w in range(len(c10)):
total1=0
count1=0
for i in range(len(a10)):
if c10[w] in a10:
total1=total1+a11[i]
count1=count1+1
average=float(total1/count1)
#break
else:
total2=0
count2=0
for i in range(len(a10)):
for j in range(len(a10[i])):
for k in range(len(c10[w])):
if c10[w][k]==a10[i][j]:
total2=total2+a11[i]
count2=count2+1
average=float(total2/count2)'
else:
continue
print 'average='+ str(average)
但是,问题是 -
如果列表的第一个元素,即['p','e']
存在,它应该进行计算并返回值,它不应该进入else循环。因为当它进入其他循环时,它也会在a11中计算其他值。
如果我在if循环后写break语句,那么它不是list的第二个元素的计算值。
输出应为:
average=2.5
average=3.0
average=2.0
答案 0 :(得分:1)
我无法确切地知道你在这里所做的事情,但这就是我如何做你所描述的。
a10=[['p', 'e'], ['t', 'h','a'],['e', 'a'],['p','e'],['a']]
c10=[['p','e'],['e','h'],['e', 'a']]
a11=[4,5,2,1,3]
# Go through c10 element by element
for c10_elem in c10:
# List of matching indexes. XXX: if same indexes can't be counted twice,
# use a set instead of a list
id = []
# Look for match in a10 and record it's index
for i, a10_elem in enumerate(a10):
if c10_elem == a10_elem:
id.append(i)
# We didn't find element level match
if not id:
# Look for char level match and record it's index
for char in c10_elem:
for i, a10_elem in enumerate(a10):
if char in a10_elem:
id.append(i)
# find average
sum = 0
for i in id:
sum = sum + a11[i]
average = sum / len(id)
print("average {}".format(average))
输出 -
$ python stack.py
average 2.5
average 3.0
average 2.0