- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我刚刚开始学习 prolog,我想知道为什么它是 dfs 而不是 bfs,以及为什么没有一个简单的方法来更改它。
ISO prolog 强制这样做吗?
最佳答案
首先,它相当容易更改。大多数 Prolog 文本都解释了如何编写执行 BFS 的谓词以及如何创建使用任意术语执行此操作的元解释器。事实是,在大学里尝试过 Prolog 的学生(基本上)都能度过使用 Prolog 的头一两周。做到这一点并不完全是一个基本 Prolog 任务,但它也不是高级 Prolog 技术。如果您在 Prolog 上花费了两个月的时间,那么这并不是一件令人生畏的事情。这听起来像是很多 Prolog,但与(例如)Java 相比,它确实不多。出于某种原因,我们希望使用 Prolog 比我们使用实际上不那么有趣的系统更快地到达终点线。
我相信 ISO 强制执行的搜索策略称为 SLD Resolution ,深度优先搜索就是源于这种解析机制。我还没有读过 ISO 标准,所以也许比我更了解的人会发表评论。我认为如果解析方法(以及深度优先或广度优先)不是强制性的,那么管理 Prolog 标准化将很困难,因为以一种方式成功的计算可能会以另一种方式进入无限循环。不指定正常程序行为的语言标准将是一个相当糟糕的标准。尽管如此,没有理由不能有一个内置的来指定备用搜索策略。
我不知道特别强制使用 DFS 的原因。使用 Prolog 一段时间后,非 DFS 的想法对我来说显然效率低下。例如,如果我添加一些代码来处理边缘情况,我每次都会使用 BFS 付费,但仅限于需要使用 DFS 的情况。我觉得 DFS 的内存效率会更高;例如,我不必跟踪一堆可能无用的代码路径。我觉得 DFS 可能更容易控制,因为我可以轻松修剪搜索树。但这些只是感觉;也许我对自然的感觉完全是我所使用的结果。缺乏基于 BFS 的 Prolog 竞争对 watch 明这可能不是一个好主意。另一方面,1980 年的低效之处仍然影响着今天的 Prolog 实现,尽管现在情况已大不相同。
关于prolog - 为什么prolog统一是深度优先搜索而不是广度优先搜索?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44360781/
我正在使用python 2.7 当我尝试在其上运行epsilon操作时出现此错误, 这是我的代码 import cv2 import numpy as np img = cv2.imread('img
1 很多程序员对互联网行业中广泛讨论的“35岁危机”表示不满,似乎所有的程序员都有着35岁的职业保质期。然而,随着AI技术的兴起,这场翻天覆地的技术革命正以更加残酷且直接的方式渗透到各行各业。程序员
我有一个包含多个子模块的项目,我想列出每个子模块的相对深度 该项目: main_project submodule1 submodule1\submodule1_1 submo
我有一张彩色图像及其深度图,它们都是由 Kinect 捕获的。我想将它投影到另一个位置(以查看它在另一个视角下的样子)。由于我没有 Kinect 的内在参数(相机参数);我该如何实现? P.S:我正在
给出了这三个网址: 1) https://example.com 2) https://example.com/app 3) https://example.com/app?param=hello 假
这个着色器(最后的代码)使用 raymarching 来渲染程序几何: 但是,在图像(上图)中,背景中的立方体应该部分遮挡粉红色实体;不是因为这个: struct fragmentOutput {
我希望能够在 ThreeJS 中创建一个房间。这是我到目前为止所拥有的: http://jsfiddle.net/7oyq4yqz/ var camera, scene, renderer, geom
我正在尝试通过编写小程序来学习 Haskell...所以我目前正在为简单表达式编写一个词法分析器/解析器。 (是的,我可以使用 Alex/Happy...但我想先学习核心语言)。 我的解析器本质上是一
我想使用像 [parse_ini_file][1] 这样的东西。 例如,我有一个 boot.ini 文件,我将加载该文件以进行进一步的处理: ;database connection sett
我正在使用 Mockito 来测试我的类(class)。我正在尝试使用深度 stub ,因为我没有办法在 Mockito 中的另一个模拟对象中注入(inject) Mock。 class MyServ
我试图在调整设备屏幕大小时重新排列布局,所以我这样做: if(screenOrientation == SCREEN_ORIENTATION_LANDSCAPE) { document
我正在 Ubuntu 上编写一个简单的 OpenGL 程序,它使用顶点数组绘制两个正方形(一个在另一个前面)。由于某种原因,GL_DEPTH_TEST 似乎不起作用。后面的物体出现在前面的物体前面
static FAST_FUNC int fileAction(const char *pathname, struct stat *sb UNUSED_PARAM, void *mo
我有这样的层次结构: namespace MyService{ class IBase { public: virtual ~IBase(){} protected: IPointer
我正在制作一个图片库,需要一些循环类别方面的帮助。下一个深度是图库配置文件中的已知设置,因此这不是关于无限深度循环的问题,而是循环已知深度并输出所有结果的最有效方法。 本质上,我想创建一个 包含系统中
如何以编程方式在树状结构上获取 n 深度迭代器?在根目录中我有 List 每个节点有 Map> n+1 深度。 我已修复 1 个深度: // DEPTH 1 nodeData.forEach(base
我正在构建一个包含大量自定义元素的 Polymer 单页界面。 现在我希望我的元素具有某种主样式,我可以在 index.html 或我的主要内容元素中定义它。可以这样想: index.html
我正在尝试每 25 秒连接到配对的蓝牙设备,通过 AlarmManager 安排,它会触发 WakefulBroadcastReceiver 以启动服务以进行连接。设备进入休眠状态后,前几个小时一切正
假设有一个有默认值的函数: int foo(int x=42); 如果这被其他人这样调用: int bar(int x=42) { return foo(x); } int moo(int x=42)
是否可以使用 Javascript 获取 url 深度(级别)? 如果我有这个网址:www.website.com/site/product/category/item -> depth=4www.w
我是一名优秀的程序员,十分优秀!