本文共 1356 字,大约阅读时间需要 4 分钟。
题目描述
有n头奶牛,已知它们的身高为 1~n 且各不相同,但不知道每头奶牛的具体身高。
现在这n头奶牛站成一列,已知第i头牛前面有Ai头牛比它低,求每头奶牛的身高。
输入格式
第1行:输入整数n。
第2…n行:每行输入一个整数Ai,第i行表示第i头牛前面有Ai头牛比它低。 (注意:因为第1头牛前面没有牛,所以并没有将它列出)
输出格式
输出包含n行,每行输出一个整数表示牛的身高。
第i行输出第i头牛的身高。
数据范围
1≤n≤105
输入样例:
5 1 2 1 0 输出样例: 2 4 5 3 1
题目分析
有n头牛,a[i]表示第i头牛前面有多少头牛比它矮。因为每一头牛只能看前面的,因此我们应该从最后一头牛开始往前算。
第i头牛前面有a[i]头牛比它矮,那么第i头牛的身高即为前i头牛中的第a[i]+1名。
我们可以用树状数组来维护一个初始为b[1]=b[2]=b[3]=…=b[n]=1的集合。b[i]=1表示身高为i的牛还未确定。然后从后往前枚举a[i],a[i]+1即为当前牛在剩余的这些牛中的身高为第a[i]+1名。这个第a[i]+1名可以用二分来算出来,最后再将这个身高存在ans[i]中即可。
代码如下
#include #include #include #include #include #include #include
转载地址:http://satn.baihongyu.com/