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

诸葛企业网站建设公司seo快速排名软件首页

诸葛企业网站建设公司,seo快速排名软件首页,电子商务网站建设与管理a卷答案,百度置顶广告多少钱目录 牛客_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://www.dtcms.com/wzjs/115680.html

相关文章:

  • 额尔古纳做网站腾讯推广平台
  • 龙岗企业网站建设抖音权重查询
  • 网站公司谁跟客户客户沟通网络营销专业如何
  • 做直播的小视频在线观看网站搜索引擎优化是什么?
  • 长春网站建设推荐网诚传媒网站流量查询工具
  • 搭建商城网站郑州外贸网站推广
  • 网站建设标准济南seo网站关键词排名
  • 湛江房产网广告开户南京seo
  • 贵阳百度公司建网站电话正规的培训学校
  • 在线观看视频网站怎么做创建软件平台该怎么做
  • 腾讯云做网站选哪个百度网页版电脑版入口
  • asp网站开发实训百度线上推广
  • 飞沐视觉北京网站建设公司资源网站优化排名优化
  • 网站建设兼职在哪找百度app下载安装普通下载
  • 河北网站建设团队资源搜索器
  • 沁阳建网站网络营销的主要内容有哪些
  • 关于网站建设的外文文献怎么制作一个网页
  • 网站后台无法修改信息电子商务与网络营销题库
  • 做网站需要会哪些知识深圳疫情最新消息
  • 郑州中扬科技网站建设公司怎么样百度站长收录
  • b2c的电子商务网站电商网站策划
  • 台州外发加工网百家号关键词排名优化
  • 做网站销售百度爱采购平台官网
  • 新钥匙网站建设网易游戏推广代理加盟
  • wordpress本地访问很慢seo外链技巧
  • 人工智能自动做网站建立一个网站需要多少钱?
  • 移动网站开发关键词排名优化价格
  • 我看别人做系统就直接网站下载上海十大营销策划公司
  • 云平台seo的搜索排名影响因素有
  • 绍兴企业自助建站seo 优化 服务