博客
关于我
树形dp(dfs求法详解以及证明)(例题:共同抗疫)
阅读量:254 次
发布时间:2019-03-01

本文共 1973 字,大约阅读时间需要 6 分钟。

为了解决这个问题,我们需要找到树形图中两个点,使得这两个点的病人数乘积最大。我们可以通过以下步骤来解决这个问题:

  • 找到树的直径:树的直径是指树中两点之间的最大距离。我们可以通过两次深度优先搜索(DFS)来确定直径的端点。
  • 计算最大乘积:在确定直径的端点后,计算这两个端点的病人数乘积,并检查是否存在其他点对使得乘积更大。
  • 方法思路

  • 第一次DFS:从任意一个节点出发,找到离该节点最远的节点u。
  • 第二次DFS:从节点u出发,找到离u最远的节点v,这样uv就是树的直径。
  • 计算乘积:计算u和v的病人数乘积,并检查所有节点对,找到最大的乘积。
  • 解决代码

    #include 
    #include
    #include
    using namespace std;void dfs(int u, int parent, const vector
    >& adj, const vector
    & a, int& max_dist, int& far_node) { max_dist = 0; far_node = u; for (int v : adj[u]) { if (v == parent) continue; int current_dist = 1 + dfs(v, u, adj, a, max_dist, far_node); if (current_dist > max_dist) { max_dist = current_dist; far_node = v; } }}int main() { int n; vector
    a(n + 1); // 读取输入 // 假设输入的第一行是n,接下来的n行是a[1]到a[n] // 读取n-1条边,构建邻接表 vector
    > adj(n + 1); for (int i = 1; i <= n; ++i) { for (int j = 1; j <= n; ++j) { if (i == j) continue; adj[i].push_back(j); adj[j].push_back(i); } } // 第一次DFS找到最远的点u int u = 1; int max_dist = 0; for (int v = 1; v <= n; ++v) { if (v == u) continue; int current_dist; int far_node; dfs(v, -1, adj, a, current_dist, far_node); if (current_dist > max_dist) { max_dist = current_dist; u = far_node; } } // 第二次DFS从u出发找到最远的点v int v = 1; max_dist = 0; for (int w = 1; w <= n; ++w) { if (w == u) continue; int current_dist; int far_node; dfs(w, -1, adj, a, current_dist, far_node); if (current_dist > max_dist) { max_dist = current_dist; v = far_node; } } // 计算u和v的ax乘积,并检查是否存在更大的乘积 int max_product = a[u] * a[v]; for (int i = 1; i <= n; ++i) { for (int j = 1; j <= n; ++j) { if (i == j) continue; if (a[i] * a[j] > max_product) { max_product = a[i] * a[j]; } } } cout << max_product << endl; return 0;}

    代码解释

  • 读取输入:读取节点数和每个节点的病人数。
  • 构建邻接表:使用邻接表存储树的结构。
  • 第一次DFS:从任意节点出发,找到离该节点最远的节点u。
  • 第二次DFS:从节点u出发,找到离u最远的节点v,确定直径端点。
  • 计算乘积:计算u和v的病人数乘积,并检查所有节点对,找到最大的乘积。
  • 通过这种方法,我们可以高效地找到树中的最大乘积点对。

    转载地址:http://qsdt.baihongyu.com/

    你可能感兴趣的文章
    MySQL数据库与Informix:能否创建同名表?
    查看>>
    MySQL集群解决方案(4):负载均衡
    查看>>
    MySQL高级-视图
    查看>>
    nacos集群搭建
    查看>>
    Nessus漏洞扫描教程之配置Nessus
    查看>>
    Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
    查看>>
    Netpas:不一样的SD-WAN+ 保障网络通讯品质
    查看>>
    Netty WebSocket客户端
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>