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;
}
相关推荐
星空椰5 小时前
Python 面向对象高级:继承与类定义详解
开发语言·python
wunaiqiezixin5 小时前
如何在C++中创建和管理线程
c++
白露与泡影5 小时前
2026大厂Java面试题大全!牛客网最新版
java·开发语言
凯瑟琳.奥古斯特5 小时前
高阶子查询题目精炼
开发语言·数据库·python·职场和发展·数据库开发
雪度娃娃5 小时前
转向现代C++——在意为改写的函数添加 override
开发语言·c++
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维差分】:[NOIP 2018 提高组] 铺设道路
c++·前缀和·差分·csp·高频考点·信奥赛·铺设道路
星马梦缘5 小时前
aaaaa
数据结构·c++·算法
喵星人工作室6 小时前
C++火影忍者1.1.2
开发语言·c++
basketball6167 小时前
C++ 中的 ptrdiff_t 详解
开发语言·c++
wunaiqiezixin7 小时前
互斥锁与自旋锁的区别
c++