• BZOJ3835: [Poi2014]Supercomputer


    Description

    Byteasar has designed a supercomputer of novel architecture. It may comprise of many (identical) processing units. Each processing unit can execute a single instruction per time unit.
    The programs for this computer are not sequential but rather have a tree structure. Each instruction may have zero, one, or multiple subsequent instructions, for which it is the parent instruction.
    The instructions of the program can be executed in parallel on all available processing units. Moreover, they can be executed in many orders: the only restriction is that an instruction cannot be executed unless its parent instruction has been executed before. For example, as many subsequent instructions of an instruction that has been executed already can be executed in parallel as there are processing units.
    Byteasar has a certain program to run. Since he likes utilizing his resources optimally, he is wondering how the number of processing units would affect the running time. He asks you to determine, for a given program and number of processing units, the minimum execution time of the program on a supercomputer with this many processing units.
     
    给定一棵N个节点的有根树,根节点为1。
    Q次询问,每次给定一个K,用最少的操作次数遍历完整棵树,输出最少操作次数。
    每次操作可以选择访问不超过K个未访问的点,且这些点的父亲必须在之前被访问过。

    Input

    In the first line of standard input, there are two integers, N and Q (1<=N,Q<=1 000 000), separated by a single space, that specify the number of instructions in Byteasar's program and the number of running time queries (for different numbers of processing units).
    In the second line of input, there is a sequence of Q integers, K1,k2,…Kq (1<=Ki<=1 000 000), separated by single spaces: Ki is the number of processing units in Byteasar's i-th query.
    In the third and last input line, there is a sequence of N-1 integers, A2,A2…An (1<=Ai<i), separated by single spaces: Ai specifies the number of the parent instruction of the instruction number i. The instructions are numbered with successive integers from 1 to N, where the instruction no. 1 is the first instruction of the program.

    Output

    Your program should print one line consisting of Q integers, separated by single spaces, to the standard output: the i-th of these numbers should specify the minimum execution time of the program on a supercomputer with Ki processing units.

    Sample Input

    20 1
    3
    1 1 1 3 4 3 2 8 6 9 10 12 12 13 14 11 11 11 11

    Sample Output

    8

    HINT

    1

    2

    3

    4

    5

    6

    7

    8

    1    

    2 3 4

    5 6 7

    8 10  

    9 12  

    11 13 14

    15 16 17

    18 19 20
    感觉还是可以意会结论的,然后斜率优化一下。
    #include<cstdio>
    #include<cctype>
    #include<queue>
    #include<cstring>
    #include<algorithm>
    #define rep(i,s,t) for(int i=s;i<=t;i++)
    #define dwn(i,s,t) for(int i=s;i>=t;i--)
    #define ren for(int i=first[x];i;i=next[i])
    using namespace std;
    const int BufferSize=1<<16;
    char buffer[BufferSize],*head,*tail;
    inline char Getchar() {
    	if(head==tail) {
    		int l=fread(buffer,1,BufferSize,stdin);
    		tail=(head=buffer)+l;
    	}
    	return *head++;
    }
    inline int read() {
        int x=0,f=1;char c=Getchar();
        for(;!isdigit(c);c=Getchar()) if(c=='-') f=-1;
        for(;isdigit(c);c=Getchar()) x=x*10+c-'0';
        return x*f;
    }
    typedef long long ll;
    const int maxn=1000010;
    int n,m,d,A[maxn],h[maxn],s[maxn],st[maxn];
    int Q[maxn],ans[maxn];
    int main() {
    	n=read();m=read();h[1]=1;
    	rep(i,1,m) A[i]=read();
    	rep(i,2,n) d=max(d,h[i]=h[read()]+1);
    	rep(i,1,n) s[h[i]]++;
    	dwn(i,d,1) s[i]+=s[i+1];
    	rep(i,1,d) s[i]=s[i+1];
    	int l=1,r=0;
    	dwn(i,d,0) {
    		while(l<r&&(ll)(Q[r-1]-Q[r])*(s[i]-s[Q[r]])>=(ll)(Q[r]-i)*(s[Q[r]]-s[Q[r-1]])) r--;
    		Q[++r]=i;
    	}
    	dwn(i,n,1) {
    		while(l<r&&(ll)i*(Q[l]-Q[l+1])<=s[Q[l+1]]-s[Q[l]]) l++;
    		ans[i]=Q[l]+(s[Q[l]]?((s[Q[l]]-1)/i+1):0);
    	}
    	rep(i,1,m) printf("%d%c",ans[min(n,A[i])],i==m?'
    ':' ');
    	return 0;
    }
    

      

     
  • 相关阅读:
    [转]DllMain中不当操作导致死锁问题的分析——DllMain中要谨慎写代码(完结篇)
    【机器学习】深入理解人工神经网络结构
    【机器学习】初识人工神经网络
    【机器学习】通过正则化解决过拟合问题
    【机器学习】逻辑回归
    【机器学习】用Octave实现一元线性回归的梯度下降算法
    【机器学习】对梯度下降算法的进一步理解
    【机器学习】从分类问题区别机器学习类型 与 初步介绍无监督学习算法 PAC
    【机器学习】感知机学习算法(PLA)
    【机器学习】1 监督学习应用与梯度下降
  • 原文地址:https://www.cnblogs.com/wzj-is-a-juruo/p/5418381.html
Copyright © 2020-2023  润新知