zoukankan      html  css  js  c++  java
  • 【LeetCode】图论 graph(共20题)

    【133】Clone Graph (2019年3月9日,复习)

    给定一个图,返回它的深拷贝。

    题解:dfs 或者 bfs 都可以

     1 /*
     2 // Definition for a Node.
     3 class Node {
     4 public:
     5     int val;
     6     vector<Node*> neighbors;
     7 
     8     Node() {}
     9 
    10     Node(int _val, vector<Node*> _neighbors) {
    11         val = _val;
    12         neighbors = _neighbors;
    13     }
    14 };
    15 */
    16 class Solution {
    17 public:
    18     Node* cloneGraph(Node* node) {
    19         if (!node) {return node;}
    20         unordered_map<Node*, Node*> memo;
    21         Node* copy = new Node(node->val,  vector<Node*>{});
    22         memo[node] = copy;
    23         queue<Node*> que;
    24         que.push(node);
    25         unordered_set<Node*> visit;
    26         visit.insert(node);
    27         while (!que.empty()) {
    28             Node* cur = que.front(); que.pop();
    29             Node* copyCur = memo[cur];
    30             for (auto& adj : cur->neighbors) {
    31                 if (memo.find(adj) == memo.end()) {
    32                     Node* copyAdj = new Node(adj->val, vector<Node*>{});
    33                     memo[adj] = copyAdj;
    34                 }
    35                 copyCur->neighbors.push_back(memo[adj]);
    36                 if (visit.find(adj) == visit.end()) {
    37                     visit.insert(adj);
    38                     que.push(adj);
    39                 }
    40             }
    41         }
    42         return copy;
    43     }
    44 };
    View Code

    【207】Course Schedule 

    【210】Course Schedule II 

    【261】Graph Valid Tree 

    【269】Alien Dictionary 

    【310】Minimum Height Trees 

    【323】Number of Connected Components in an Undirected Graph 

    【332】Reconstruct Itinerary 

    【399】Evaluate Division 

    【444】Sequence Reconstruction 

    【684】Redundant Connection 

    【685】Redundant Connection II 

    【743】Network Delay Time 

    【765】Couples Holding Hands 

    【785】Is Graph Bipartite? 

    【802】Find Eventual Safe States 

    【839】Similar String Groups 

    【841】Keys and Rooms 

    【854】K-Similar Strings 

    【928】Minimize Malware Spread II 

  • 相关阅读:
    kettle的转换组件
    kettle的输出组件
    js的touch事件的实际引用
    touchstart,touchmove,touchend触摸事件的小小实践心得
    Android使用ViewPager实现左右循环滑动及轮播效果
    jQuery漂亮图标的垂直导航菜单
    c#使用WebClient登录网站抓取登录后的网页
    从网页抓取数据的一般方法
    c#通过oledb获取excel文件表结构信息
    c#中高效的excel导入sqlserver的方法
  • 原文地址:https://www.cnblogs.com/zhangwanying/p/9964164.html
Copyright © 2011-2022 走看看