统计树的最小层数以及位于该层数上的叶子节点个数即可。

  代码里建树我用了邻接链表的存储方式——链式前向星,不了解的可以参考,非常好用:

  http://www.cnblogs.com/chenxiwenruo/p/4513754.html

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <algorithm>
  4. #include <string.h>
  5. #include <cmath>
  6. using namespace std;
  7. /*
  8. 计算最小的层数与该层数上的叶子节点数目即可
  9. 建树用的是链式前向星模板,不了解的参考:
  10. http://www.cnblogs.com/chenxiwenruo/p/4513754.html
  11. */
  12. const int maxn=+;
  13. int head[maxn];
  14. int tot=;
  15. int minlayer=maxn;
  16. int cnt=;
  17. struct Edge{
  18. int to,next;
  19. }edge[maxn];
  20. void add(int x,int y){
  21. edge[tot].next=head[x];
  22. edge[tot].to=y;
  23. head[x]=tot++;
  24. }
  25. void init(){
  26. memset(head,-,sizeof(head));
  27. tot=;
  28. }
  29.  
  30. void dfs(int i,int layer){
  31. if(head[i]==-){
  32. if(layer<minlayer){
  33. cnt=;
  34. minlayer=layer;
  35. }
  36. else if(layer==minlayer){
  37. cnt++;
  38. }
  39. return;
  40. }
  41. for(int k=head[i];k!=-;k=edge[k].next){
  42. int v=edge[k].to;
  43. dfs(v,layer+);
  44. }
  45. }
  46. int main()
  47. {
  48. int n;
  49. double p,r;
  50. scanf("%d %lf %lf",&n,&p,&r);
  51. int a,b;
  52. init();
  53. for(int i=;i<n;i++){
  54. scanf("%d",&a);
  55. for(int j=;j<a;j++){
  56. scanf("%d",&b);
  57. add(i,b);
  58. }
  59. }
  60. dfs(,);
  61. double sum=p;
  62. for(int i=;i<minlayer;i++){
  63. sum*=(+r/);
  64. }
  65. printf("%.4lf %d",sum,cnt);
  66. return ;
  67. }

PAT甲题题解-1106. Lowest Price in Supply Chain (25)-(dfs计算树的最小层数)的更多相关文章

  1. PAT Advanced 1106 Lowest Price in Supply Chain (25) [DFS,BFS,树的遍历]

    题目 A supply chain is a network of retailers(零售商), distributors(经销商), and suppliers(供应商)– everyone in ...

  2. [建树(非二叉树)] 1106. Lowest Price in Supply Chain (25)

    1106. Lowest Price in Supply Chain (25) A supply chain is a network of retailers(零售商), distributors( ...

  3. 1106. Lowest Price in Supply Chain (25)

    A supply chain is a network of retailers(零售商), distributors(经销商), and suppliers(供应商)-- everyone invo ...

  4. PAT (Advanced Level) 1106. Lowest Price in Supply Chain (25)

    简单dfs #include<cstdio> #include<cstring> #include<cmath> #include<vector> #i ...

  5. 【PAT甲级】1106 Lowest Price in Supply Chain (25分)

    题意:输入一个正整数N(<=1e5),两个小数P和R,分别表示树的结点个数和商品原价以及每下探一层会涨幅的百分比.输出叶子结点深度最小的商品价格和深度最小的叶子结点个数. trick: 测试点1 ...

  6. PAT甲级——1106 Lowest Price in Supply Chain(BFS)

    本文同步发布在CSDN:https://blog.csdn.net/weixin_44385565/article/details/90444872 1106 Lowest Price in Supp ...

  7. PAT 甲级 1106 Lowest Price in Supply Chain

    https://pintia.cn/problem-sets/994805342720868352/problems/994805362341822464 A supply chain is a ne ...

  8. PAT 1106 Lowest Price in Supply Chain

    A supply chain is a network of retailers(零售商), distributors(经销商), and suppliers(供应商)-- everyone invo ...

  9. PAT甲题题解-1006. Sign In and Sign Out (25)-找最小最大

    判断哪个人最早到,哪个人最晚走水,就是找最大值最小值 #include <iostream> #include <cstdio> #include <algorithm& ...

随机推荐

  1. Oracle 截取字符串(截取固定分隔符中间的字符

    #### Oracle 截取字符串(截取固定分隔符中间的字符) #### ####  oracle 取固定分隔符之间的字符--方法一 substr+ instrSELECT  substr('12JP ...

  2. Hadoop HBase概念学习系列之HLog(二)

    首先,明确,HRegion服务器包含两大部分:HLog和HRegion. HLog用来存储数据日志,采用的是先写日志的方式. 当用户需要更新数据的时候,数据会被分配到对应的HRegion服务器上提交修 ...

  3. Flink 的广播变量

    Flink 支持广播变量,就是将数据广播到具体的 taskmanager 上,数据存储在内存中,这样可以减缓大量的 shuffle 操作: 比如在数据 join 阶段,不可避免的就是大量的 shuff ...

  4. kudu基础入门

    1.kudu介绍 1.1 背景介绍 在KUDU之前,大数据主要以两种方式存储: (1)静态数据: 以 HDFS 引擎作为存储引擎,适用于高吞吐量的离线大数据分析场景.这类存储的局限性是数据无法进行随机 ...

  5. runloop是iOS系统上的actor模式

    runloop是iOS系统上的actor模式(单线程派发的)

  6. 【转】android Toast大全(五种情形)建立属于你自己的Toast

    Toast用于向用户显示一些帮助/提示.下面我做了5中效果,来说明Toast的强大,定义一个属于你自己的Toast. 1.默认效果 代码 Toast.makeText(getApplicationCo ...

  7. WorldWind源码剖析系列:网络下载类WebDownload

    网络下载类WebDownload封装了对请求的瓦片进行网络下载的相关操作.该类使用了两个委托类型和一个枚举类型. 该类的类图如下. 网络下载类WebDownload各个字段和属性的含义说明如下: st ...

  8. DNS主从复制及子域(三)

    主从DNS 主辅DNS服务器数据同步的过程,首先master DNS服务器每 次修改完成并重启服务后,将传送notify给所有的Slave DNS服务器. Slave DNS服务器将查询Master服 ...

  9. Working With JSON

    JavaScript对象表示法(JSON)是用于将结构化数据表示为JavaScript对象的标准格式,通常用于在网站上表示和传输数据(例如从服务器向客户端发送一些数据,因此可以将其显示在网页上). J ...

  10. 支持-webkit-前缀的浏览器修改滚动条样式

    //血槽宽度 ::-webkit-scrollbar { width:8px; height:8px; } //拖动条 ::-webkit-scrollbar-thumb { background-c ...