zoukankan      html  css  js  c++  java
  • A* 寻路算法学习

    代码小记

      1 #include <iostream>
      2 #include <list>
      3 
      4 struct POINT {
      5     int X;
      6     int Y;
      7 };
      8 
      9 // G: 起点到当前点的成本
     10 // H: 当前点到终点的估算成本
     11 // F: G,H之和
     12 struct MapNode {
     13     int G;
     14     int H;
     15     int F;
     16     bool can_pass;
     17     POINT pt;
     18     MapNode* pParent;
     19 
     20     MapNode() : G(0), H(0), F(0), can_pass(false), pParent(NULL) {}
     21 
     22     bool operator==(const MapNode& other) {
     23         return (other.pt.X == pt.X && other.pt.Y == pt.Y);
     24     }
     25 
     26     bool operator!=(const MapNode& other) {
     27         return !(*this == other);
     28     }
     29 };
     30 
     31 bool nodeCompare(MapNode* p1, MapNode* p2) {
     32     return (p1->F <  p2->F);
     33 }
     34 
     35 int maps[20][30] = {
     36     1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
     37     1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
     38     1,0,1,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,1,1,1,1,1,1,0,1,
     39     1,0,1,1,1,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,1,
     40     1,0,0,0,1,0,1,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,1,
     41     1,0,1,1,1,0,1,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,1,
     42     1,0,1,0,1,0,1,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,1,1,1,1,0,1,
     43     1,0,1,0,1,0,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0,0,0,1,0,1,
     44     1,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,0,1,0,1,
     45     1,0,1,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0,0,0,1,0,1,
     46     1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,1,1,1,1,0,1,
     47     1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0,0,0,1,0,1,
     48     1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,0,1,0,1,
     49     1,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,0,0,0,0,0,0,0,1,0,1,
     50     1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,1,1,1,1,0,1,
     51     1,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,1,0,1,
     52     1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,1,
     53     1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,1,0,1,1,1,1,1,1,0,1,
     54     1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,
     55     1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1
     56 };
     57 
     58 MapNode* findNode(std::list<MapNode*>& nodes, const POINT& pt) {
     59     for(std::list<MapNode*>::iterator it = nodes.begin();
     60             it != nodes.end();
     61             ++it) {
     62         if((*it)->pt.X == pt.X && (*it)->pt.Y == pt.Y) {
     63             return *it;
     64         }
     65     }
     66     return NULL;
     67 }
     68 
     69 void pathFinding() {
     70     std::list<MapNode*> all;
     71     std::list<MapNode*> open;
     72     std::list<MapNode*> close;
     73 
     74     for(int row=0; row<20; ++row) {
     75         for(int col=0; col<30; ++col) {
     76             MapNode* pNode = new MapNode;
     77             pNode->pt.X = row;
     78             pNode->pt.Y = col;
     79             pNode->can_pass = (maps[row][col] == 0 ? true : false);
     80             all.push_back(pNode);
     81         }
     82     }
     83 
     84     POINT pt_start = {1, 1};
     85     POINT pt_target = {10, 16};
     86     MapNode* pStart = findNode(all, pt_start);
     87     MapNode* pTarget = findNode(all, pt_target);
     88 
     89     open.push_back(pStart);
     90     while(!open.empty()) {
     91         open.sort(nodeCompare);
     92         MapNode *pNode = open.front();
     93         if (*pNode == *pTarget) {
     94             break;
     95         }
     96         open.pop_front();
     97         close.push_back(pNode);
     98         // 查找周围节点并将合适的加入open
     99         int ptMask[8][3] = { // x坐标相对位置,y坐标相对位置,移动耗费
    100             {-1, -1, 14}, // 左上
    101             {0 , -1, 10}, // 正上
    102             {1 , -1, 14}, // 右上
    103             {-1, 0 , 10}, // 正左
    104             {1 , 0 , 10}, // 正右
    105             {-1, 1 , 14}, // 左下
    106             {0 , 1 , 10}, // 正下
    107             {1 , 1 , 14}  // 右下
    108         };
    109         for(int i=0; i<8; ++i) {
    110             POINT pt;
    111             pt.X = pNode->pt.X + ptMask[i][0];
    112             pt.Y = pNode->pt.Y + ptMask[i][1];
    113 
    114             if(pt.X > 0 && pt.X < 30 && pt.Y >0  && pt.Y < 20) {
    115                 MapNode* pChildNode = findNode(all, pt);
    116                 if(!pChildNode->can_pass || NULL != findNode(close, pt)) {
    117                     // 如果pNodeLT不可抵达的或者它在 close list 中,忽略它
    118                 } else {
    119                     if(NULL == findNode(open, pt)) {
    120                         // 如果pNodeLT不在 open list 中,把它加入 open list,
    121                         // 并且把当前方格设置为它的父亲,记录该方格的F,G和H值
    122                         pChildNode->pParent = pNode;
    123                         pChildNode->G = pChildNode->pParent->G + ptMask[i][2];
    124                         pChildNode->H = 10 * (abs(pTarget->pt.X - pt.X) + abs(pTarget->pt.Y - pt.Y));
    125                         pChildNode->F = pChildNode->G + pChildNode->H;
    126                         open.push_back(pChildNode);
    127                     } else {
    128                         // 如果pNodeLT已经在 open list 中,检查这条路径 ( 即经由
    129                         // 当前方格到达它那里 ) 是否更好,用 G 值作参考。更小的 G
    130                         // 值表示这是更好的路径
    131                         int tG = pNode->G + ptMask[i][2];
    132                         if(tG < pChildNode->G) {
    133                             pChildNode->pParent = pNode;
    134                             pChildNode->G = tG;
    135                             pChildNode->H = 10 * (abs(pTarget->pt.X - pt.X) + abs(pTarget->pt.Y - pt.Y));
    136                             pChildNode->F = pChildNode->G + pChildNode->H;
    137                         }
    138                     }
    139                 }
    140             }
    141         }
    142     }
    143     if(NULL != pTarget->pParent) {
    144         MapNode* pNode = pTarget;
    145         std::cout << "path is : " << std::endl;
    146         do {
    147             std::cout << "pt[" << pNode->pt.X << ", " << pNode->pt.Y << "] ->" << std::endl;
    148             pNode = pNode->pParent;
    149         } while(*pNode != *pStart);
    150         std::cout << "pt[" << pNode->pt.X << ", " << pNode->pt.Y << "]" << std::endl;
    151     }
    152 }
    153 
    154 int main() {
    155 
    156     pathFinding();
    157 
    158     system("pause");
    159 
    160     return 0;
    161 }
  • 相关阅读:
    第五章:数组 结构体 和联合体
    第四章:用户自定义和枚举数据类型
    第三章:systemverilog文本值和数据类型
    阶段一:读几本经济学书
    第二章:systemverilog声明的位置
    数据结构-B树
    UDP的崛起
    vim使用
    sudo apt-get update
    计算机组成原理——浮点数表示方法
  • 原文地址:https://www.cnblogs.com/mforestlaw/p/4802671.html
Copyright © 2011-2022 走看看