最新华为OD机试真题——(E卷,100分) - 高矮个子排队(python)

问题描述

我们有一队小朋友,他们的身高用正整数数组表示,例如 {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

说明:

你可能感兴趣的:(华为od,python,算法)