- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
谁能给我解释一下 AC-1、AC-2 和 AC-3 算法?我必须理解它们并用代码实现它们。但首先,我想很好地理解它们,但它们太难了,我无法理解。有什么帮助吗?顺便说一句,我对回溯不太熟悉,我试着阅读和观看有关它的视频,但还是一样!谢谢,
最佳答案
我将快速解释一下回溯和 AC-3。但是如果你想更详细地了解这一点,你应该阅读这本书:
Artificial Intelligence: A Modern Approach : Stuart Russel and Peter Norvig 2003 Prentice Hall
这本书作为约束满足问题 (CSP) 的一章解释了所有关于 AC-3 和回溯的内容。
您首先需要了解什么是 CSP。 CSP 包含:
现在,当您拥有 CSP 时,您希望为所有变量赋予值并继续遵守限制。当所有变量都有一个值并同时遵守所有限制时,CSP 得到解决。
回溯是一种算法,可让您找到解决此问题的方法。所以你从一个空状态 {} 开始,这意味着没有变量有值。然后你从变量集中选择一个变量(你用来选择你选择的变量的顺序可能会影响算法的性能有一些启发式方法可以用于此,如 MRV - 最小值剩余......)。现在假设我们首先选择 A,现在我们从域 Da 中选取一个值(您选取该值的顺序也可能使用启发式)。想象一下 Da = {1,2,3}。我们选择 1。现在我们检查 A = 1 是否没有违反任何限制,否则它不是一个好的归因。如果不是,那么让我们设置 A = 1,现在我们处于 {A=1} 状态。现在让我们继续这样做。想象一下,你选择 B 和一个值 1。这将违反 A > B + 2 的限制。现在你有两个选择,如果你有另一个值来测试 B,你可以尝试一下。如果不是,这意味着 A = 1 是错误的,您需要返回状态 {} 并尝试 A = 2 等等。
这是回溯的伪代码:
function backtracking (csp) return a solution or fails
return recursive_backtracking({}, csp) // {} is the initial state
function recursive_backtracking (state, csp) return a solution or fails
if state is complete then return state // all variable have a value
var <- selectNotAtributedVariable(csp)
for each value in orderValues(csp, var) // values of the domain of var
if var = value is consistent given the restrictions
add {var = value} to state
result = recursive_backtracking(state, csp)
if result != fail then return result
remove {var = value} from state
return fail
请注意 selectNotAtributedVariable 和 orderValues 是启发式的(它们可能只返回集合的第一个元素)。
现在什么是 AC-3,为什么以及何时使用它?首先 AC-3 用作预处理步骤。你可以这样使用它:
function solveCSP(csp)
ac3(csp)
return backtracking(csp)
这回答了何时。基本上,AC-3 会在回溯期间检测您在归因中遇到的冲突,并删除它们。如何?通过切割 CSP 中变量的域。因此,当两个变量共享一个限制时,我们说两者之间存在弧线。如果满足以下条件,则您说 A 和 B 之间的弧是一致的:
假设您有以下限制 A > B 和 B > C。您将有以下一组弧:{A->B, B->A, B->C, C->B}现在 AC-3 所做的是它从上面的集合中选择一个弧,A->B,对于 A 可以采用的每个 a 值,尝试检查是否存在 B 可以根据限制采用的值 b。如果是,则 A 的域保持不变,如果不是,则从 A 的域中删除值 a。每次从域中删除一个值时,您都必须重新检查 A 的邻居(在本例中)。我的意思是您需要重新检查弧 B->A(不是因为它们在上面的集合中)。
所以,这是伪代码:
function AC3(csp) returns csp possibly with the domains reduced
queue, a queue with all the arcs of the CSP
while queue not empty
(X,Y) <- getFirst(queue)
if RemoveConsistentValues(X,Y, csp) then
foreach Z in neighbor(X) - {Y}
add to queue (Z,X)
return csp
function RemoveConsistentValues(X, Y, csp) returns true if a value was removed
valueRemoved <- false
foreach x in domain(X, csp)
if there's no value of domain(Y, csp) that satisfies the restriction between X and Y then
remove x from domain(X, csp)
valueRemoved <- true
return valueRemoved
关于algorithm - AC-1、AC-2 和 AC-3 算法(弧相容性),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28257422/
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 9 年前。 Improve this q
半径为r的圆上的点p(x,y)与圆心O(x0,y0)的关系: x = x0+rcosA; y = y0+rsinA ,A为弧度 1、圆 复制代码 代码如下:
我正在尝试找到一种方法来计算两条弧线之间的交点。我需要用它来确定在视觉上圆弧的右半边有多少,左边有多少。我考虑创建右半部分的弧线,并将其与实际弧线相交。但是我花了很多时间来解决这个问题,所以我想在这里
这听起来可能是一个新手问题,但我是 iOS 开发新手。 我在我的项目中跟踪了代码,该项目启用了 ARC,但我在执行时遇到错误(访问错误),并且想了解问题的原因并解决它。 按下某些按钮后,将在 MTCl
我想使用圆弧连接两个 SVG 点(例如两个圆的中心)。如果只有一个连接,则线 ( ) 将是一条直线。如果有两个连接,则两者都将是圆形的并且是对称的,这样: 所以,事实上,有一些规则: 一切都应该与连
我正在尝试实现多级饼图 我的初始代码在这里:JSFIDDLE var departments = [ { "name": "Sales", "color": "green",
我想在我的布局中制作一个弧形 View ,我尝试使用一个库但它不能正常工作,我如何制作这样的拱形 View 并在其上附加一个按钮,例如: 我尝试了一些代码,但它们在平板电脑和不同尺寸的屏幕上无法正常显
我有点 X 和 A, A',... 坐标: X [x,y](是起点) A [a,b], A'[a',b']等(是终点) 我还知道 Angular XCA、XCA'等 我找不到计算弧的公式,类似于图片上
我有一个 ViewController,它从 CoreData 获取对象并用它们构建一个 UITableView。当用户按下一行时,我得到报告文学对象并使用以下方法将其传递给下一个 View Cont
我有一个带有弧形的 Canvas ,里面有一些标签。 这是 fiddle 链接 - Fiddle下面是代码: var canvas = document.getElementById("myC
如何使用 css 创建这样的 Angular 弧? 这是入门模板:https://codepen.io/anon/pen/rwraXG 我希望我能够使用黑色外部 div 和红色内部 div,并使用边框
只是想完全理解 ARC。 MyView *testView = [[MyView alloc] init]; __weak MyView *weakView = testView; [weakView
假设我有一条线,我想为这条线设置动画,首先线是隐藏的,经过一点一点的线出现并完成后,我的问题是在 Android 中可以做到这一点还是我必须使用 Adobe After Effect? 更新 :
更新:2013 年 11 月 20 日:此问题仍未解决。 我正在尝试在自定义 View 中以动画方式创建圆圈。我想制作圆周的动画 - 在动画开始时有一个圆弧,在动画结束时圆是完整的。 我按照这个答案成
This is a basic code to create a pie chart for protocol distribution. In my .csv file, I have two co
我有一个 NSArray 对象,在我的 UIViewController 中使用。我可以将其声明为 ivar 或属性。这两种方法都有什么优点(考虑到我使用的是 ARC)? 选项 1: @interfa
此刻 Canvas 以不同的速度和大小绘制 15 个从 ltr 移动的圆圈。当其中一个离开窗口时,它将被设置为开始。问题是 Canvas 在圆圈之间画线,我不知道为什么?有人可以帮忙吗? window
我最近在这里和其他网站上阅读了很多关于 IBOutlets 应该强还是弱的文章。官方判定它们应该是弱的,除非它们引用顶级 xib 对象。 这很好。 然而,我还不清楚为什么将它们设置为强或弱实际上会对应
我有一个 CIImage,我正试图在鼠标沿路径拖动时画线。我可以这样做吗? 我正在为 mac 构建一个应用程序,我是 Core Image 的新手。 最佳答案 您需要先创建一个图形上下文,然后从中检索
我有一个使用 CAShapeLayer 绘制的圆弧,我希望它围绕圆的中心旋转。我正在尝试使用“transform.rotation”属性上的 CABasicAnimation 来获取此动画。但是旋转似
我是一名优秀的程序员,十分优秀!