C++:Highest Price in Supply Chain

供应链是由零售商(零售商)、经销商(经销商)和供应商(供应商)------将产品从供应商到客户的所有环节构成的网络。

从一个根供应商开始,链上每个成员都以价格 PP 向自己的供应商采购产品,并以比 PP 高 rr% 的价格销售或分销。假设除根供应商外,供应链上的每个成员只有一个供应商,且不存在供应循环。

现在给定一个供应链,请告诉我们从零售商处可以获得的最高价格。

输入格式:

每个输入文件包含一个测试用例。第一行包含三个正数:NN(≤105≤105,供应链成员总数,编号为 0 到 N−1N−1)、PP(根供应商的价格)和 rr(每层经销或零售的价格增幅百分比)。第二行包含 NN 个整数 SiSi​,表示第 ii 个成员的供应商编号,根供应商的 SrootSroot​ 为 −1−1。行内数字以空格分隔。

输出格式:

输出一行,包含两个数:可预期的最高价格和达到该价格的零售商数量。最高价格保留两位小数,二者之间用一个空格分隔。保证结果不超过 10101010。

样例输入:

复制代码
9 1.80 1.00
1 5 4 4 -1 4 5 3 6

样例输出:

复制代码
1.85 2
cpp 复制代码
#include <iostream>
#include <vector>
#include <queue>
#include <bits/stdc++.h>
using namespace std;
int n;double p,r;
int main(){
    cin>>n>>p>>r;
    if(n==1){
        printf("%.2lf 1",p);
        return 0;
    }
    vector<int> v[n+5];
    int high[n+5]={0};
    int root=-1;
    for(int i=0;i<n;++i){
        int u;cin>>u;
        if(u==-1)root=i;
        else v[u].push_back(i);
    }
    int l=1;
    queue<int> q;
    q.push(root);
    while(!q.empty()){
        int u=q.front();
        q.pop();
        for(int j=0;j<v[u].size();++j){
            q.push(v[u][j]);
            high[v[u][j]]=high[u]+1;
        }
    }
    vector<int> vv;
    for(int i=0;i<n;++i){
        vv.push_back(high[i]);
    }
    sort(vv.begin(),vv.end());
    int la=vv.size()-1;
    long long maxx=vv[la];
    long long cnt=0;
    while(vv[la]==vv[vv.size()-1]){
        la--;
        cnt++;
    }
    double sum=0;
    sum=p;
    for(int i=0;i<vv[vv.size()-1];++i){
        sum*=1.0+r/100.0;
    }
    printf("%.2lf %lld",sum,cnt);
    return 0;
}
相关推荐
不吃香菜学java4 小时前
Redis的java客户端
java·开发语言·spring boot·redis·缓存
BestOrNothing_20155 小时前
C++零基础到工程实战(4.3.3):vector数组访问与遍历
c++·迭代器·stl·vector·动态数组
贵沫末5 小时前
python——打包自己的库并安装
开发语言·windows·python
charlie1145141915 小时前
通用GUI编程技术——图形渲染实战(三十三)——Direct2D与Win32/GDI互操作:渐进迁移实战
c++·图形渲染·gui·win32
文祐5 小时前
C++类之虚函数表及其内存布局(一个子类继承一个父类)
开发语言·c++
zuowei28896 小时前
华为网络设备配置文件备份与恢复(上传、下载、导出,导入)
开发语言·华为·php
xiaohe076 小时前
超详细 Python 爬虫指南
开发语言·爬虫·python
嗑嗑嗑瓜子的猫6 小时前
Java!它值得!
java·开发语言
xiaoshuaishuai86 小时前
C# GPU算力与管理
开发语言·windows·c#
lsx2024067 小时前
SVN 创建版本库
开发语言