如何计算Prolog中列表中元素出现的次数

如何计算Prolog中列表中元素出现的次数

本文介绍了如何计算Prolog中列表中元素出现的次数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我是 prolog 的新手,这就是为什么这个问题对你来说很容易,但我找不到答案.有人可以帮我吗.

我只是想要

一个计数函数 s.t

count([c,c,a,a,b,b,d,a,c,b,d,d,a], O).

它将返回列表成员出现的次数.

 O = [[a, 4], [b, 3], [c, 3], [d, 3]]
解决方案

以下是根据我之前的回答给"删除列表中的重复项 (Prolog)" 和 这个以前的答案对问题AUBUC 的 Prolog 联合".

list_item_subtracted_count0_count/5 源自 list_item_subtracted/3.list_counts/2 派生自 list_setB/2,它们都是 此处定义的.

list_item_subtracted_count0_count([], _, [], N,N).list_item_subtracted_count0_count([A|As], E, Bs1, N0,N) :-if_(A = a>E,( Bs1 = Bs , N1 是 N0+1 ),( Bs1 = [A|Bs], N1 = N0 )),list_item_subtracted_count0_count(As, E, Bs, N1,N).list_counts([], []).list_counts([X|Xs], [X-N|Ys]) :-list_item_subtracted_count0_count(Xs, X, Xs0, 1,N),list_counts(Xs0, Ys).

这是 OP 给出的查询:

?- list_counts([c,c,a,a,b,b,d,a,c,b,d,d,a], Xss).Xss = [c-3,a-4,b-3,d-3].% 确定性地成功

注意CountsXN对的顺序对应于XsX的第一次出现:

?- list_counts([a,b,c,d], Xss).Xss = [a-1,b-1,c-1,d-1].?- list_counts([d,c,b,a], Xss).Xss = [d-1,c-1,b-1,a-1].

最后,让我们考虑所有可能的列表Es—以递增的长度公平地枚举:

?- 长度(Es, N), list_counts(Es,Xss).N = 0, Es = [], Xss = [];N = 1, Es = [A], Xss = [A-1];N = 2, Es = [A,A], Xss = [A-2];N = 2, Es = [A,B], Xss = [A-1,B-1], dif(B,A);N = 3, Es = [A,A,A], Xss = [A-3];N = 3, Es = [A,A,B], Xss = [A-2,B-1], dif(B,A);N = 3, Es = [A,B,A], Xss = [A-2,B-1], dif(B,A);N = 3, Es = [B,A,A], Xss = [B-1,A-2], dif(A,B), dif(A,B);N = 3, Es = [A,B,C], Xss = [A-1,B-1,C-1], dif(C,A), dif(C,B), dif(B,A)...

i m new in prolog that s why may be the question is easy for you but i couldnt find the answer. Can someone please help me.

I just want

a count function s.t

count([c,c,a,a,b,b,d,a,c,b,d,d,a], O).

it will returns the number of occurences of the list members.

 O = [[a, 4], [b, 3], [c, 3], [d, 3]]
解决方案

The following is based on my previous answer to "Remove duplicates in list (Prolog)" and on this previous answer to the question "Prolog union for A U B U C".

list_item_subtracted_count0_count/5 is derived from list_item_subtracted/3.list_counts/2 is derived from list_setB/2, which were both defined here.

list_item_subtracted_count0_count([], _, [], N,N).
list_item_subtracted_count0_count([A|As], E, Bs1, N0,N) :-
   if_(A = E,
       ( Bs1 =    Bs , N1 is N0+1 ),
       ( Bs1 = [A|Bs], N1 =  N0   )),
   list_item_subtracted_count0_count(As, E, Bs, N1,N).

list_counts([], []).
list_counts([X|Xs], [X-N|Ys]) :-
   list_item_subtracted_count0_count(Xs, X, Xs0, 1,N),
   list_counts(Xs0, Ys).

Here's the query the OP gave:

?- list_counts([c,c,a,a,b,b,d,a,c,b,d,d,a], Xss).
Xss = [c-3,a-4,b-3,d-3].                    % succeeds deterministically

Note the order of pairs X-N in Counts corresponds to the first occurrence of X in Xs:

?- list_counts([a,b,c,d], Xss).
Xss = [a-1,b-1,c-1,d-1].

?- list_counts([d,c,b,a], Xss).
Xss = [d-1,c-1,b-1,a-1].

Last, let's consider all possible lists Es—enumerated fairly with ascending lengths:

?- length(Es, N), list_counts(Es, Xss).
   N = 0, Es = [],      Xss = []
;  N = 1, Es = [A],     Xss = [A-1]
;  N = 2, Es = [A,A],   Xss = [A-2]
;  N = 2, Es = [A,B],   Xss = [A-1,B-1],     dif(B,A)
;  N = 3, Es = [A,A,A], Xss = [A-3]
;  N = 3, Es = [A,A,B], Xss = [A-2,B-1],     dif(B,A)
;  N = 3, Es = [A,B,A], Xss = [A-2,B-1],     dif(B,A)
;  N = 3, Es = [B,A,A], Xss = [B-1,A-2],     dif(A,B), dif(A,B)
;  N = 3, Es = [A,B,C], Xss = [A-1,B-1,C-1], dif(C,A), dif(C,B), dif(B,A)
...

这篇关于如何计算Prolog中列表中元素出现的次数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-14 11:57