亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Prolog-計算列表中的重復次數

Prolog-計算列表中的重復次數

慕容森 2019-09-27 15:58:53
我正在嘗試瀏覽列表并計算給定單詞出現的次數。到目前為止,我已經做到了:count_repetitions([_], [], 0).count_repetitions([Word], [Word|Tail], Count):-   count_repetitions([Word], Tail, X),    Count is X + 1.count_repetitions([Word], [Z|Tail], Count):-   Word \= Z,    count_repetitions([Word], Tail, Count).因此查詢?- count_repetitions([yes],[yes,and,yes,and,no], X).將給出X = 2。這似乎起作用?,F在,我需要編寫一個謂詞,以表形式輸出包含搜索詞及其出現次數的列表X = [(yes - 2)]。我完全被困住了,有什么建議嗎?
查看完整描述

3 回答

?
侃侃爾雅

TA貢獻1801條經驗 獲得超16個贊

庫(集合)通常被低估:


count(L, C) :-

    aggregate(set(W-N), aggregate(count, member(W, L), N), C).

產量


1 ?- count([a,b,a],C).

C = [a-2, b-1].

所以,更簡單


count(W, L, W-N) :-

    aggregate(count, member(W, L), N).

產量


?- count(a, [a,b,a], C).

C = a-2.

基于setof,aggregate / 3可以更好地控制變量的量化(即哪些值被聚合),但是如果沒有解決方案,它將失敗,而不是在需要時產生0。


在這種情況下,基于findall / 3的aggregate_all / 3將返回0,但不允許使用量化說明符。


查看完整回答
反對 回復 2019-09-27
  • 3 回答
  • 0 關注
  • 901 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號