我有一个列表
List = [['Dev', 'Jon'], ['Dev', 'Darin'], ['Dev', 'Hans'],
['Test', 'Richard'], ['Test', 'Mike'], ['Test', 'Jon'], ['Test', 'Hans'],
['Chef', 'Bozho'], ['Chef', 'Mike'], ['Chef', 'Jon']] .
我想计算每个人出现的次数,并逐步增加他的时间 例如,结果如下:
[['Dev', 'Jon', 1], ['Dev', 'Darin',1], ['Dev', 'Hans', 1],
['Test', 'Richard', 1], ['Test', 'Mike', 1], ['Test', 'Jon', 2], ['Test', 'Hans', 2],
['Chef', 'Bozho', 1], ['Chef', 'Mike', 2], ['Chef', 'Jon', 3]]
非常感谢:)
答案 0 :(得分:0)
解决方案可能是这样的:
count([], _, Zs, Zs).
count([[X,Y]|T], Ys, Zs, Us) :- select([Y,C], Ys, Ys1), C1 is C+1, append(Zs, [[X,Y,C1]], Zs1), count(T, [[Y,C1]|Ys1], Zs1, Us), !.
count([[X,Y]|T], Ys, Zs, Us) :- append(Zs, [[X,Y,1]], Zs1), count(T, [[Y,1]|Ys], Zs1, Us).
transform(L1, L2) :- count(L1, [], [], L2).
我们使用Ys
列表来存储所有人的计数器,使用Zs
列表来累积每个具有相应索引的人。希望它有所帮助。