我正在尝试学习 Prolog。这是我使用这种语言的第一步。作为练习,我想编写可以识别一些扑克牌的程序(同花顺,四类,满屋等)。
我在 Prolog 中寻找良好的卡片表示。我需要有可能检查一张卡是否比另一张大,卡是否适合等等。
我从代码开始:
rank(2).
rank(3).
rank(4).
rank(5).
rank(6).
rank(7).
rank(8).
rank(9).
rank(t).
rank(j).
rank(q).
rank(k).
rank(a).
value(2, 2).
value(3, 3).
value(4, 4).
value(5, 5).
value(6, 6).
value(7, 7).
value(8, 8).
value(9, 9).
value(t, 10).
value(j, 11).
value(q, 12).
value(k, 13).
value(a, 14).
%value(a, 1).
suite(d).
suite(h).
suite(c).
suite(s).
rank_bigger(X, Y) :-
value(X, A),
value(Y, B),
A > B.
这使 mi 有可能检查等级 A 是否大于例如 J。
但我不确定如何表示单卡。这个表示应该包含牌的等级和花色。Ace 也有一些问题,因为 Ace 有 14 级,但它也可以是 1 顺子。
所以我的问题是,如果我想制定如下规则,如何表示卡片:
isStraight(C1, C2, C3, C4, C5) :-
[...]
或者
isStraightFlush(C1, C2, C3, C4, C5) :-
[...]
我敢肯定,如果您了解语言,这是一个简单的问题,但是从 C 或 python 之类的语言“转换”思维并不容易。:-)