当前位置: 首页 > wzjs >正文

贵阳网站建设推广网站开发用什么网站

贵阳网站建设推广,网站开发用什么网站,中铁建设企业门户登录,河南省建设执业资格中心网站目录 牛客_Pre-Post(英文题树的遍历_排列组合) 解析代码 牛客_Pre-Post(英文题树的遍历_排列组合) 解析代码 这道题本质上其实是一个排列组合问题。通过前序和后序我们虽然还原不出来树,但是谁是谁的子树我们还是知道…

目录

牛客_Pre-Post(英文题树的遍历_排列组合)

解析代码


牛客_Pre-Post(英文题树的遍历_排列组合)


解析代码

        这道题本质上其实是一个排列组合问题。通过前序和后序我们虽然还原不出来树,但是谁是谁的子树我们还是知道的。假设我们的前序是abejkcfghid,后序是jkebfghicda,那么我们根据前序,就能知道:

  1. 最多可以有13颗子树,也就是每一层都有13个可能位置。
  2. a是根,第一棵子树的根是b。
  3. 通过后树我们能知道,b的子树有j、k、e、b共四个结点。
  4. 再回到前序,向前走4个结点,下一棵子树的根是 c。
  5. 以此类推,最终得到 a 为根的下一层共有 3 棵子树。

        三颗子树长这样:前序 bejk cfghi d 后序 jkeb fghic d 则这一层一共的可能性就是13个空位随便挑3个摆这3颗子树,那么有13*12*11 / 3 * 2种可能。

#include <iostream>
#include <string>
#include <vector>
using namespace std;struct SubTree // 保存子树的前序和后序遍历结果
{SubTree(const string& pre, const string& post): _pre(pre), _post(post){}string _pre;string _post;
};
long long Fac(int n) // 求n的阶乘
{long long f = 1;for (int i = 1; i <= n; ++i){f *= i;}return f;
}
long long CalcCom(int n, int m) // 求:C(n,m) = C(n, n-m)
{m = m < (n - m) ? m : (n - m);long long r = 1;for (int i = n; i >= n - m + 1; i--){r *= i;}return r / Fac(m);
}
// 找根节点的所有子树
vector<SubTree> CalcSubTree(const string& pre, const string& post)
{size_t subRootPreIdx = 1;size_t postFirst = 0; // 子树在后序遍历结果中第一个元素的位置vector<SubTree> v;while (subRootPreIdx < pre.size()){// 确定子树的根节点char subRoot = pre[subRootPreIdx];// 确定根在后序遍历结果中的位置char subRootPostIdx = post.find(subRoot);// 计算该子树中节点的个数size_t subTreeNodeCount = subRootPostIdx - postFirst + 1;// 找到该棵子树前序遍历结果 - 找到该棵子树后序遍历结果SubTree subTree(pre.substr(subRootPreIdx, subTreeNodeCount), post.substr(postFirst, subTreeNodeCount));v.push_back(subTree);// 根新下一课子树根在前序遍历结果中的下标subRootPreIdx += subTreeNodeCount;// 更新下一棵子树中第一个节点在后序遍历结果中的下标postFirst += subTreeNodeCount;}return v;
}long long CalcTreePossible(int m, const string& pre, const string& post)
{// 如果树中只有1个节点---树的可能性就是唯一的if (1 == pre.size())return 1;// 先找出根节点的所有子树vector<SubTree> v = CalcSubTree(pre, post);// 计算根节点子树的可能性---组合long long result = CalcCom(m, v.size());for (auto& e : v)result *= CalcTreePossible(m, e._pre, e._post);return result;
}int main()
{int m = 0;string pre, post;while (cin >> m >> pre >> post){if (m == 0)break;cout << CalcTreePossible(m, pre, post) << endl;}return 0;
}

文章转载自:

http://0l9C1em6.tnnfy.cn
http://v3vFNqw1.tnnfy.cn
http://7KjkWl2s.tnnfy.cn
http://Na7EgKVK.tnnfy.cn
http://Oulr2C6J.tnnfy.cn
http://0opB3aCw.tnnfy.cn
http://oZaAJ5QK.tnnfy.cn
http://BigDEeFx.tnnfy.cn
http://CcZ0rGr5.tnnfy.cn
http://fFNn862K.tnnfy.cn
http://zhaT1C84.tnnfy.cn
http://yU6LeUiG.tnnfy.cn
http://kvQyHrqd.tnnfy.cn
http://LHgs0rRe.tnnfy.cn
http://tD9LtmCG.tnnfy.cn
http://BM3r0Iv2.tnnfy.cn
http://MSmNTClj.tnnfy.cn
http://fdkT9Xnk.tnnfy.cn
http://f18Pil79.tnnfy.cn
http://zCRedoNy.tnnfy.cn
http://Qd1vHqO4.tnnfy.cn
http://0TIu8pG1.tnnfy.cn
http://izKkhfQI.tnnfy.cn
http://fAXCeCzl.tnnfy.cn
http://6vG5C5WU.tnnfy.cn
http://FGBpXlcg.tnnfy.cn
http://IN5JcJbk.tnnfy.cn
http://DC19qiYV.tnnfy.cn
http://71dcSwl6.tnnfy.cn
http://oFeVcDZk.tnnfy.cn
http://www.dtcms.com/wzjs/692926.html

相关文章:

  • 网站建设管理员工工资多少施工企业附属加工厂广联达
  • 重庆企业网络推广网站wordpress 微信打不开
  • 网站建设推广多少钱wordpress建站模版
  • 下沙建设局网站网站建设的四个步骤
  • 网站建设话术开场白动漫网站源码自动采级
  • 怎样建设学校网站百度网站首页网址
  • 南昌做网站设计广州地铁2号线
  • aps网站服务建设小橡皮私人定制app软件
  • 专做袜子的网站维护网站是什么意思
  • 网站备案最新备案号长春网络推广
  • 旅游信息网站开发背景网站自助建站系统
  • 哪些公司做网站好app开发网站建设前景
  • 建立网站 域名 服务器今天重庆新闻头条
  • 数学建模代做网站wordpress 忘记密码页面
  • 建立网站很重要的要素是什么百度百度百度一下
  • 关于网站开发人员保密协议中国机械加工网易下拉教程
  • 二网站手太仓网站建设网站推广
  • 网站建设198网站开发兼职团队
  • 公司网站维护是做什么的阿里ace 安装wordpress 并修改
  • 冷色调网站网站的信息量能做什么
  • 大连建设工程信息网怎么注册搜索seo
  • 手机网站可以做动态吗商标查询软件哪个app好
  • 购物网站建设代理商购物网站开发方案
  • 那个网站可以做公示房价2024年暴跌
  • 中文域名网站怎么发布信息大型网站的建设
  • 建站网站建设哪个好怎样做网站才不能被攻破
  • 如何打造网站网站权限怎么设置
  • 做电影下载网站还赚钱吗中文企业网站模板下载
  • 泰安肥城网站建设网站推广话术与技巧
  • 高校网站推广方案小程序的功能与作用