QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1819|回复: 3
打印 上一主题 下一主题

数学建模常用算法—A*算法

[复制链接]
字体大小: 正常 放大

3503

主题

538

听众

5990

积分

  • TA的每日心情
    开心
    2017-2-7 15:12
  • 签到天数: 691 天

    [LV.9]以坛为家II

    社区QQ达人 元老勋章 发帖功臣 新人进步奖 优秀斑竹奖 金点子奖 原创写作奖 最具活力勋章 助人为乐奖 风雨历程奖

    群组2013年国赛赛前培训

    群组2014年地区赛数学建模

    群组数学中国第二期SAS培训

    群组物联网工程师考试

    群组2013年美赛优秀论文解

    跳转到指定楼层
    1#
    发表于 2016-3-2 11:46 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    A*算法

     A*算法中更一般的引入了一个估价函数f,其定义为f=g+h。其中g为到达当前节点的耗费,而h表示对从当前节点到达目标节点的耗费的估计。其必须满足两个条件:

    1、h必须小于等于实际的从当前节点到达目标节点的最小耗费h*。

    2、f必须保持单调递增。

     A*算法的控制结构与广度搜索的十分类似,只是每次扩展的都是当前待扩展节点中f值最小的一个,如果扩展出来的节点与已扩展的节点重复,则删去这个节点。如果与待扩展节点重复,如果这个节点的估价函数值较小,则用其代替原待扩展节点,具体算法描述如下:
    范例:一个3*3的棋盘中有1-8八个数字和一个空格,现给出一个初始态和一个目标态,要求利用这个空格,用最少的步数,使其到达目标态。

    问题分析:预期值定义为h=|x-dx|+|y-dy|。

         估价函数定义为f=g+h。
    <Type>

     Node(节点类型)=Record
     Situtation:TSituation(当前节点状态);
     g:Integer;(到达当前状态的耗费)
     h:Integer;(预计的耗费)
     f:Real;(估价函数值)
     Last:Integer;(父节点)
    End
    <Var>
     List(节点表):Array[1..Max(最多节点数)] of Node(节点类型);
     open(总节点数):Integer;
      close(待扩展节点编号):Integer;
     New-S:Tsituation;(新节点)
    <Init>
     List<-0;
     open<-1;
     close<-0;
     List[1].Situation<- 初始状态;
     <Main Program>
     While (close<open(还有未扩展节点)) and
      (open<Max(空间未用完)) and
      (未找到目标节点) do
     Begin
      Begin
       close:=close+1;
       For I:=close+1 to open do (寻找估价函数值最小的节点)
       Begin
        if List.f<List[close].f then
        Begin
         交换List和List[close];
        End-If;
       End-For;
      End;
     For I:=1 to TotalExpendMethod do(扩展一层子节点)
     Begin
      New-S:=ExpendNode(List[close].Situation,I)
      If Not (New-S in List[1..close]) then
       (扩展出的节点未与已扩展的节点重复)
       Begin
        If Not (New-S in List[close+1..open]) then
        (扩展出的节点未与待扩展的节点重复)
        Begin
         open:=open+1;
         List[open].Situation:=New-S;
         List[open].Last:=close;
         List[open].g:=List[close].g+cost;
         List[open].h:=GetH(List[open].Situation);
         List[open].f:=List[open].h+List[open].g;
        End-If
        Else Begin
         If List[close].g+cost+GetH(New-S)<List[same].f then
          (扩展出来的节点的估价函数值小于与其相同的节点)
         Begin
          List[same].Situation:= New-S;
          List[same].Last:=close;
          List[same].g:=List[close].g+cost;
          List[same].h:=GetH(List[open].Situation);
          List[same].f:=List[open].h+List[open].g;
         End-If;
       End-Else;
      End-If
     End-For;
    End-While;
     对A*算法的改进--分阶段A*:

     当A*算法出现数据溢出时,从待扩展节点中取出若干个估价函数值较小的节点,然后放弃其余的待扩展节点,从而可以使搜索进一步的进行下去。
    87e6a3852b86e212bd74941313b7a2c6.png 7579d3573799afe3962848d2c0ca36dc.jpg

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

    3503

    主题

    538

    听众

    5990

    积分

  • TA的每日心情
    开心
    2017-2-7 15:12
  • 签到天数: 691 天

    [LV.9]以坛为家II

    社区QQ达人 元老勋章 发帖功臣 新人进步奖 优秀斑竹奖 金点子奖 原创写作奖 最具活力勋章 助人为乐奖 风雨历程奖

    群组2013年国赛赛前培训

    群组2014年地区赛数学建模

    群组数学中国第二期SAS培训

    群组物联网工程师考试

    群组2013年美赛优秀论文解

    回复

    使用道具 举报

    3503

    主题

    538

    听众

    5990

    积分

  • TA的每日心情
    开心
    2017-2-7 15:12
  • 签到天数: 691 天

    [LV.9]以坛为家II

    社区QQ达人 元老勋章 发帖功臣 新人进步奖 优秀斑竹奖 金点子奖 原创写作奖 最具活力勋章 助人为乐奖 风雨历程奖

    群组2013年国赛赛前培训

    群组2014年地区赛数学建模

    群组数学中国第二期SAS培训

    群组物联网工程师考试

    群组2013年美赛优秀论文解

    回复

    使用道具 举报

    3503

    主题

    538

    听众

    5990

    积分

  • TA的每日心情
    开心
    2017-2-7 15:12
  • 签到天数: 691 天

    [LV.9]以坛为家II

    社区QQ达人 元老勋章 发帖功臣 新人进步奖 优秀斑竹奖 金点子奖 原创写作奖 最具活力勋章 助人为乐奖 风雨历程奖

    群组2013年国赛赛前培训

    群组2014年地区赛数学建模

    群组数学中国第二期SAS培训

    群组物联网工程师考试

    群组2013年美赛优秀论文解

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-8-22 17:13 , Processed in 0.676867 second(s), 69 queries .

    回顶部