问题描述
我们有一队小朋友,他们的身高用正整数数组表示,例如 {5, 3, 1, 2, 3}
。现在我们希望按照“高”“矮”“高”“矮”的顺序排列小朋友,使得每个“高”位置的小朋友要比相邻的位置高或等,且每个“矮”位置的小朋友要比相邻的位置矮或等。与此同时,我们还需要确保移动的总距离最小。
移动距离定义
- 若一个小朋友从距当前位置
i
移动到位置j
,则移动距离为|i - j|
。
输入描述
输入是一行以空格分隔的正整数,表示小朋友的身高。
输出描述
输出为排序后的小朋友身高,以空格分隔,同时输出最小移动距离。
样例输入输出
示例1
输入
4 1 3 5 2
输出
4 1 5 2 3
说明: 排列后满足要求,移动的距离和为 1。
示例2
输入
1 1 1 1 1
输出
1 1 1 1 1
说明: 所有小朋友身高相同,不需要移动。
示例3
输