当前位置: 首页>>代码示例>>C++>>正文


C++ Path::PushPath方法代码示例

本文整理汇总了C++中Path::PushPath方法的典型用法代码示例。如果您正苦于以下问题:C++ Path::PushPath方法的具体用法?C++ Path::PushPath怎么用?C++ Path::PushPath使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Path的用法示例。


在下文中一共展示了Path::PushPath方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: GetPath

bool Player::GetPath(vector<Point> & OutPath,Point Start, Point End, int MaxRange){
    OutPath.clear();
    if (Start == End){
        OutPath.push_back(Start);
        return true;
    }
    Array2d<bool> HasPassed(false);
    struct Path{
        Point P;
        Path * LastPath;
        Path(){ LastPath = NULL; }
        Path(Point InP, Path * InLastPath){
            P = InP;
            LastPath = InLastPath;
        };
        void PushPath(vector<Point> & OutPath){
            if (LastPath != NULL)
                LastPath->PushPath(OutPath);
            OutPath.push_back(P);
        }
    };
    vector<vector<Path>> Paths(MaxRange);
    //sets the original point in the vector
    Paths[0].push_back(Path(Start, NULL));
    for (int r = 0; r < MaxRange - 1; r++){
        vector<Path> & PrevPath = Paths[r];
        vector<Path> & CurPath = Paths[r+1];
        for (Path & PPath : PrevPath){
            for (Point NewP:SquareIterate(PPath.P, 1)){
                //not necessary, but possibly a more efficient alternative to the bool array method
                //bool IsFurthurFromDest = GetBoardDistance(NewP, Start) >= GetBoardDistance(PPath.P, Start);
                //bool IsCloserToEnd = GetBoardDistance(NewP, End) <= GetBoardDistance(PPath.P, End);
                if (!HasPassed[NewP] && BlankPoint(NewP)){// && (IsFurthurFromDest || IsCloserToEnd)){
                    HasPassed[NewP] = true;
                    CurPath.push_back(Path(NewP, &PPath));
                    if (NewP == End){
                        Path NewPath = Path(NewP, &PPath);
                        NewPath.PushPath(OutPath);
                        return true;
                    }
                }
            }
        }
    }
    return false;
}
开发者ID:weepingwillowben,项目名称:qtwargame,代码行数:46,代码来源:player.cpp

示例2: PushPath

 void PushPath(vector<Point> & OutPath){
     if (LastPath != NULL)
         LastPath->PushPath(OutPath);
     OutPath.push_back(P);
 }
开发者ID:weepingwillowben,项目名称:qtwargame,代码行数:5,代码来源:player.cpp


注:本文中的Path::PushPath方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。