[笔记]极大极小过程的alpha-beta剪枝不可与记忆化搜索一起使用

今天做SGU 423,WA得我眼泪汪汪。后来发现原来这个问题很早就被何牛提到过:

极大极小过程的alpha-beta剪枝不可与记忆化搜索一起使用。

原因是这样的:

在一个博弈图中,可能存在这样的情况:一个状态有不止一个前继。

比如,设状态u和状态v都可以转移到同一个状态w。

假设极大极小过程先搜索到u,为了得到u的估值f(u),我们要搜索w并且给本次搜索一个估值上界beta(u),一旦在w的搜索过程中发现f(w)当前值>=beta(u),则立刻停止搜索因为f(u)的估值不会用到w这个分支。这就是alpha-beta剪枝。

但是请注意,此时并不保证f(w)的正确性,我们仅仅知道f(w)>=beta(u)而已。这次剪枝仅仅保证u的搜索结果的正确性。

为了得到v的估值f(v)我们会再次搜索到w,注意此时所给的估值上界是beta(v)而不是beta(u),也就是这两次搜索对于w的限制是不同的。如果使用记忆化,就相当于默认f(w)为精确值。但是由于之前的剪枝,我们得到的仅仅是f(w)的一个界而已,这里就会出现错误。更确切地,当beta(v)>beta(u)时,就会由于u与beta(u)对于w的限制被记忆,导致计算v的估值所需要的w的信息被误剪。

T_T

顺便贴个alpha-beta剪的思路模板吧:

//alpha-beta剪枝
//不可以和记忆化搜索混用
//需要在外部记录状态(局面以及当前先手者),通过make_move和unmake_move函数进行改变。
int ab(int alpha, int beta, int depth, bool pass) {// 当前最佳估值,预设为负无穷大int best = -INF;// 如果到达预定的搜索深度if (depth <= 0) {// 计算出估值return eval();}// 尝试每个后继状态foreach (move) {// 试着走后继状态if (make_move(move)) {// 如果合法,对所形成的局面进行递归搜索int now = -alpha_beta(-beta, -alpha, depth-1, 0);// 恢复原来的局面
            unmake_move(move);// 如果这步棋引发剪枝if (now >= beta) {// 停止对当前局面的搜索,立即返回。return now;}// 如果这步更好if (now > best) {// 保存更好的结果best = now;// 更新估值下限if (now > alpha) {alpha = now;}}}}// 如果没有合法后继,则此步为弃着if (best == -INF) {// 如果上一步也是弃着,表明对局结束if (pass) {// 计算出精确值return calc();}// 否则这步棋弃着,局面不变先后手互换
        make_move(PASS_MOVE);// 递归搜索,并标明该步弃着。best = -alpha_beta(-beta, -alpha, depth, 1);// 恢复原来的局面
        unmake_move(PASS_MOVE);}// 返回最佳估值return best;
}

转载于:https://www.cnblogs.com/jffifa/archive/2012/08/01/2618960.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/548380.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[转载] AUML——Schedules and Events

来源&#xff1a;http://www.auml.org/ Schedules and Events Class and Sequence Diagrams specifications Plan for Work and Milestones for the Class and Sequence Diagrams specifications: May 2003 - Initial draft of language specifications for Class and Sequenc…

JQuery Datatables 获取实例及如何进行全局设置

可以使用以下三种方法获得一个新的Datatables API实例&#xff1a; $( selector ).DataTable();$( selector ).dataTable().api();new $.fn.dataTable.Api( selector ); 可以通过以下方法进行 Datatables的全局设置 //将以下JS代码单据引入后&#xff0c;默认之后所有的datatab…

Juniper SA SSL ×××配置宁盾DKEY短信动态密码步骤

1. 方案简介 传统的双因子认证技术是基于硬件令牌方式&#xff0c;IT管理员会为每个用户分配分发一只令牌&#xff0c;用户登录时输入令牌上显示的6位随即数字&#xff0c;即可完成登录是目前最为常用的强身份认证方案&#xff0c;它最大优点在于认证响应度高&#xff0c;然而采…

JQuery Datatables Ajax dataSrc的使用

Datatables在默认Ajax的情况下&#xff0c;dataSrc会去读取名称为data属性的数组 $(#myTable).DataTable( {ajax: {url: /api/myData,dataSrc: },columns: [ ... ] } );// 或者使用标准的写法&#xff0c;指定在data中去找&#xff0c;效果和上面写法一样 $(#myTable).DataTabl…

JQuery Datatables 数据操作

DataTables有4种内置数据操作&#xff0c;每一个都可能使用正交&#xff08;独立&#xff09;数据源。这四种操作如下&#xff0c;重点看前三个。 display(string)//用于显示的数据 sort(string)//用于排序的数据 filter(string)//用于过滤的数据 type(string)//类型检测数据 比…

apache 添加下载文件头

AddType application/octet-stream .rar #windowsAddType application/octet-stream .apk #androidAddType application/octet-stream .ipa #苹果

JQuery Datatables单元格内显示数据太长,截取部分显示功能

//初始化表格 var oTable $("#example").DataTable({ajax: {url: "dataList.action",data: {args1: "我是固定传参的值&#xff0c;在服务器接收参数[args1]"}},columns: [{data: "content",render: function(data, type, row, meta)…

JQuery Datatables辅助函数

数字辅助函数。number辅助函数提供了轻松格式化数字的功能。处理数字时&#xff0c;您可能经常希望添加格式&#xff0c;前缀和后缀字符&#xff08;比如货币标示符&#xff09;&#xff0c;使用千位分隔符并制定数字的精度。使用number辅助函数可以做到这些。 数字辅助函数包含…

多表替代密码

多表替代密码转载于:https://www.cnblogs.com/LoveFishC/archive/2012/08/03/3846672.html

SqlServer用SQL语句将查出的数据直接插入到另一个张的表中

示例代码&#xff1a; INSERT INTO dbo.Barcode( BarNo ,FiscalYear ,FiscalMonth ,BarType ,ItemId ,ItemName ,WhId ,WhName ,CurrentWhId ,CurrentWhName ,ItemQty ,LotNo ,StUserId ,StUserName ,StDatetime ,RKVou ,CKVou ,DeprecatedUserId ,DeprecatedUserName ,Depre…

Oracle-物化视图

Oracle-物化视图 介绍&#xff1a;oracle物化视图是包括一个查询结果的数据库对象&#xff0c;它是远程数据的的本地副本&#xff0c;或者用来生成基于数据表求和的汇总表。物化视图存储基于远程表的数据&#xff0c;也可以称为快照。对于复制&#xff0c;物化视图允许你在本地…

windows7 删除hiberfil.sys文件的方法

在cmd模式下输入命令“powercfg -h off”—回车 如果想还原,同样运行那条命令,把off改成on.就行了 此设置将彻底禁用休眠。转载于:https://blog.51cto.com/hujizhou/954329

JS判断一个数字是否为小数

<script type"text/javascript">var x 4.23323;//测试的数字var y String(x).indexOf(".") 1;//获取小数点的位置var count String(x).length - y;//获取小数点后的个数if(y > 0) {alert("这个数字是小数&#xff0c;有" count &…

使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错。字符串的长度超过了为 maxJsonLength 属性设置的值。

一、报错截图如下所示&#xff1a; 二、报错代码&#xff1a; List<BarcodeEntity> Lists _IBarcode.GetBarcodeByWhAndType(WhId,BarcodeType); return Json(Lists,JsonRequestBehavior.AllowGet); 三、修正代码&#xff1a; List<BarcodeEntity> Lists _IBa…

Software

Bioimage related : 1. Cellprofiler: http://www.cellprofiler.org/index.shtml MATLAB 2012: http://matlab.tuc.gr/R2012b/转载于:https://www.cnblogs.com/stoneresearch/archive/2012/08/06/4336578.html

Jquery 获取select选中的value、text

<select id"select"><option value"123">456</option> </select> var a $(#select).val(); // 结果为 123var b $(#select option:selected).val(); // 结果为 123var d $(#select option:selected).attr(value); //…

DevExpress之TreeList节点绑定图片

最近在项目中使用到了DX中的TreeList控件绑定数据源时在每个节点前显示特点的图片&#xff1b;查阅相关资料实现方法如下&#xff1a;1.首先打开VS2010新建一个WINFROM应用程序&#xff1b; 2.在WINFROM应用程序中增加DX中的TreeList控件&#xff1b;如下图&#xff1a; 3.在窗…

ASP.NET MVC从数据库读取、存入图片

一、DEMO效果 先选择图片&#xff0c;点击上传后&#xff0c;即可在照片预览中看到照片。如果需要更改&#xff0c;重新上传就可覆盖原图片。 二、代码 页面端&#xff0c;这里有个细节&#xff1a;再次上传后&#xff0c;如果<img>的URL不变&#xff0c;浏览器会从缓存中…

.net密码找回

using System;using System.Collections.Generic;using System.Text;using System.Net.Mail;using System.IO; /// <summary> /// sendEmail 的摘要说明 /// </summary> public static class sendEmail { static sendEmail() { // // TODO…