@yexiaoqi
2022-05-24T11:45:27.000000Z
字数 817
阅读 526
刷题
华为机试
题目:在学校中,N个小朋友站成一队,第i个小朋友的身高为height[i],第i个小朋友可以看到第一个比自己身高更高的小朋友j,那么j是i的好朋友,(要求:j>i)
请重新生成一个列表,对应位置的输出是每个小朋友的好朋友的位置,如果没有看到好朋友,请在该位置用0代替,小朋友人数范围 0~40000
难度:*
输入描述:第一行输入N,N表示有N个小朋友,第二行输入N个小朋友的身高height[i],都是整数
输出描述:输出N个小朋友的好朋友的位置
示例1:
输入:2
100 95
输出:0 0
说明:第一个小朋友身高100站在队伍末尾向队首看,没有比他身高高的小朋友,所以输出第一个值为0。第二个小朋友站在队首前面也没有比他身高高的小朋友所以输出第二个值为0
示例2:
输入:8
123 124 125 121 119 122 126 123
输出:1 2 6 5 5 6 0 0
说明:123的好朋友是1位置上的124
124的好朋友是2位置上的125
125的好朋友是6位置上的126,依此类推
public class Main{
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
int n = sc.nextInt();
int[] height = new int[n];
for (int i=0; i<n; i++){
height[i] = sc.nextInt();
}
StringBuilder sb = new StringBuilder();
for (int i=0; i<n; i++){
int index = 0;
for (int j=i+1; j<n; j++){
if (height[j]>height[i]) {
index = j;
break;
}
}
sb.append(index).append(" ");
}
System.out.println(sb.toString().trim());
}
}
}