- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
问题陈述:
我正在尝试在 Prolog (SWI-Prolog) 中生成所有自然数对,
即正式具有函数f(X,Y)
,这样:
调用 f(X,Y)
后未绑定(bind)变量 X
, Y
,对于每对自然数 (m, n) 存在一个 n0 ,因此在按分号 n0 次后,Prolog 将返回 (X,Y)=(m,n)
.
尝试失败:
我希望使用 Cantor's pairing function 编写函数.简而言之,它枚举对如下:(0,0), (1,0), (0,1), (2,0), (1,1), (0,2), (3,0 ), (2,1), (1,2), (0,3), (4,0)...
我表达如下:
gen(0,0). % 'root'
gen(M,0) :- gen(0, X), M is X+1. % 'jump to the previous diagonal'
gen(M,N) :- gen(X, Y), M is X-1, N is Y+1, N > 0. % 'a step inside a diagonal'
然而,由于 Prolog 搜索的实际工作方式,这最终导致第二条规则反复调用自身,adinfinitem,最终由于堆栈空间不足而崩溃(它在此之前返回的唯一结果是 (0,0) 和 (1, 0),然后它卡住了,反复失败关于'0是0 + 1'的第二条规则)。
range(Min, _, Min).
range(Min, Max, Val) :- NewMin is Min+1, Max >= NewMin, range(NewMin, Max, Val).
natnum(0).
natnum(N) :-
natnum(N0),
N is N0 + 1.
gen(A,B) :-
natnum(N),
range(0, N, B),
A is N - B.
使用时:
?- gen(X,Y).
X = 0,
Y = 0 ;
X = 1,
Y = 0 ;
X = 0,
Y = 1 ;
X = 2,
Y = 0 ;
X = 1,
Y = 1 ;
X = 0,
Y = 2 ;
X = 3,
Y = 0
and so on...
最佳答案
我给你一个开始:
让我们从一个谓词开始,它在回溯时创建所有自然数,每个解产生一个这样的数字:
纳特姆(0)。
natnum(N) :-
N #= N0 + 1,
纳特数(N0)。
示例查询:
?- natnum(N)。
N = 0 ;
N = 1 ;
N = 2;
N = 3 ;
等等
然后,我们观察到我们可以通过限制每对的总和来生成这样的对而不会陷入无限循环。例如:
对(A-B):-
纳特姆(N),
N #>= A + B,
#>= 0,
B #>= 0,
标签([A,B])。
示例查询:
?- 对(P)。
P = 0-0 ;
P = 0-0 ;
P = 0-1 ;
P = 1-0 ;
P = 0-0 ;
P = 0-1 ;
P = 0-2 ;
P = 1-0 ;
P = 1-1;
P = 2-0 ;
P = 0-0 ;
P = 0-1 ;
P = 0-2 ;
P = 0-3;
P = 1-0 ;
P = 1-1。
这显然不是完美的:例如,一些对被冗余报告。但是,总体思路应该很清楚:使用良好的构建 block 来控制对的生成。
关于prolog - 如何在 Prolog 中生成所有自然数对?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48053493/
我不知道引用引用的对象的值如何。顺便说一句,我不是在谈论整数。 我想做这个方法。 swapNN(NaturalNumber j, NaturalNumber n) 我希望交换 j 和 n 的引用,但是
给定一个向量 v w [1] -2 -1 0 1 2 3 4 7 8 9 10 11 12 13 19 20 21 22 23 24 25 最佳答案 另一种方法是 c(t(sapp
给定前 n 个自然数的 k 组合,出于某种原因,我需要在 itertools 返回的那些组合中找到这种组合的位置。 combination(range(1,n),k)(原因是这样我可以使用 list
在根据代码摘录识别复杂性或最坏情况时,我了解什么是大 O 表示法。 在类里面,我被教导说,当谈到复杂性和大 O 表示法时,我们忽略低于 M 的小参数 n 和常数因子 C 。 这是在类里面给我的: In
我需要编写一个算法来解决这个练习,有什么建议吗? 练习: 我们有一个矩形,分成 n x m 个正方形,每个正方形都是自然数。编写一个函数来计算这个矩形内有多少个幻方。 幻方是 k x k (k>=2)
我是一名优秀的程序员,十分优秀!