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


C++ priority_queue::emplace方法代码示例

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


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

示例1: handle_node_edges

// Helper function for find_path_between_intersections. Iterates through the
// outward edges of the given node. Calculates the heuristic and cost of every
// outward node, then adds them to the wavefront. If an outward node has not
// been added to nodeMap, it is added.
void handle_node_edges(const LatLon& endPosition, Node& node
        , std::unordered_map<unsigned, Node>& nodeMap
        , std::priority_queue<waveElem, std::vector<waveElem>, std::greater<waveElem>>& wavefront) {
    std::vector<unsigned> segmentIDs = find_intersection_street_segments(node.id);
    unsigned id;
    for (const unsigned& segmentID : segmentIDs) {
        StreetSegmentEnds ends = getStreetSegmentEnds(segmentID);
        if (ends.from == node.id)
            id = ends.to;
        else if (!getStreetSegmentOneWay(segmentID))
            id = ends.from;
        else
            continue;
        if (id == node.fromNodeID || id == node.id)
            continue;
        double cost = node.cost + find_segment_travel_time(segmentID);
        if (node.reachingEdge != ULONG_MAX
            && getStreetSegmentStreetID(node.reachingEdge) != getStreetSegmentStreetID(segmentID))
            cost += 0.25;
        LatLon position = getIntersectionPosition(id);
        if (nodeMap.find(id) == nodeMap.end()) {
            nodeMap.insert(std::make_pair(id, Node(id, segmentID, node.id, ULONG_MAX)));
            // calculate the heuristic using the ideal case of
            // traversing the remaining distance directly to the
            // destination at 100 km/h
            double heuristic;
            heuristic = find_distance_between_two_points(endPosition
                                                       , position);
            heuristic = heuristic/1000.0/100.0*60.0;
            wavefront.emplace(id, segmentID, node.id, cost, heuristic);
        } else if (cost < nodeMap.find(id)->second.cost) {
            double heuristic;
            heuristic = find_distance_between_two_points(endPosition
                                                       , position);
            heuristic = heuristic/1000.0/100.0*60.0;
            wavefront.emplace(id, segmentID, node.id, cost, heuristic);
        } 
    }
}
开发者ID:Luissh22,项目名称:Map-Application,代码行数:43,代码来源:m3.cpp

示例2: main

int main() {
    
    
    std::ios_base::sync_with_stdio(false);
    
    cin >> N >> M;
    
    int low = 999999;
    
    for (int i = 1; i <= N; i++)
    {
        for (int j = 1; j <= M; j++)
        {
            char t = ' ';
            cin >> t;
            arr[j][i] = t;
            dist[j][i][0] = 99999;
            dist[j][i][1] = 99999;
            dist[j][i][2] = 99999;
            dist[j][i][3] = 99999;
            scanned[j][i][0] = false;
            scanned[j][i][1] = false;
            scanned[j][i][2] = false;
            scanned[j][i][3] = false;
        }
    }
    
    dist[1][1][2] = 0;
    
    bfsQ.emplace(bfs_data(1, 1, '>', 0));
    
    while (!bfsQ.empty())
    {
        
        int x = bfsQ.top().x;
        int y = bfsQ.top().y;        //curent vertex
        char dir = bfsQ.top().dir;
        bfsQ.pop();
        
        
        if (!(x > M || x<1 || y>N || y < 1) && arr[x][y] != '#')
        {
            
            int n_x = x, n_y = y;
            
            int t=-1; //direction indicator
            if (dir == '^')
            {
                n_y--;
                t = 0;
            }
            else if (dir == 'v')
            {
                n_y++;
                t = 1;
            }
            else if (dir == '>')
            {
                n_x++;
                t = 2;
            }
            else if (dir == '<')
            {
                n_x--;
                t = 3;
            }
            
            
            if (!scanned[x][y][t])
            {
                
                if (x == M)
                {
                    if(dist[x][y][t] < low)
                        low = dist[x][y][t];
                    
                    break;
                }
                
                scanned[x][y][t] = true;
                
                
                
                if (arr[n_x][n_y] != '#')
                {
                    if (!scanned[n_x][n_y][t])
                    {
                        if (dist[x][y][t] < dist[n_x][n_y][t])
                        {
                            dist[n_x][n_y][t] = dist[x][y][t];
                            bfsQ.push(bfs_data(n_x, n_y, dir, dist[x][y][t]));
                        }
                        
                    }
                }
                else
                {
                    
                    n_y = y;
                    n_x = x;
//.........这里部分代码省略.........
开发者ID:drPytho,项目名称:programmerings-tr-ning,代码行数:101,代码来源:xobust+-+dijkstra.cpp

示例3: put

 inline void put(
     T item,
     Number priority)
 {
     elements.emplace(priority, item);
 }
开发者ID:jinsin5,项目名称:paradoxpath,代码行数:6,代码来源:path.cpp

示例4: push

 void push(T node, float priority) {
     elements.emplace(priority, node);
 }
开发者ID:swalker29,项目名称:GameDesign,代码行数:3,代码来源:AStarEnemyTrackBehavior.cpp


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