解题思路
这道题看似简单,但看完题目可能会觉得不止这么简单。因为要保证移动距离最小,这意味着可能存在多种情况需要多次比较。不过,实际并没有那么复杂。
比如在用例1中,乍一看好像有点问题:直接让5和2交换位置,得到的结果是:4 1 3 2 5,这样也符合题意,而且移动距离只有1,似乎更符合要求。
然而,这样想的同学可能忽略了题目中的一句关键提示:“第一个从‘高’位开始排”。这句话的意思是,我们只需要从第一个小朋友开始排列,并在发现不符合要求的排队顺序时,就进行交换。这样大大降低了题目难度。
代码解释
为了实现将小朋友的身高按照“高矮交替”的顺序排列,代码中使用了以下判断条件:
heights[i] != heights[j] &am