標籤:java 華為 演算法 解決方案
題目:
* 給定一個數組input[] ,如果數組長度n為奇數,
* 則將數組中最大的元素放到 output[] 數組最中間的位置,
* 如果數組長度n為偶數,
* 則將數組中最大的元素放到 output[] 數組中間兩個位置偏右的那個位置上,
* 然後再按從大到小的順序,依次在第一個位置的兩邊,
* 按照一左一右的順序,依次存放剩下的數。
* 例如:
* input[] = {3, 6, 1, 9, 7}
* output[] = {3, 7, 9, 6, 1};
* input[] = {3, 6, 1, 9, 7, 8}
* output[] = {1, 6, 8, 9, 7, 3}
分析: 題目雖然新規定了排列規則, 但是還是存在大小順序的, 所以我們可以先對數組先進行排序, 然後再將排好序的數組重新按照規則再組合
代碼如下:
package com.wenj.test;
/*
* 給定一個數組input[] ,如果數組長度n為奇數,
* 則將數組中最大的元素放到 output[] 數組最中間的位置,
* 如果數組長度n為偶數,
* 則將數組中最大的元素放到 output[] 數組中間兩個位置偏右的那個位置上,
* 然後再按從大到小的順序,依次在第一個位置的兩邊,
* 按照一左一右的順序,依次存放剩下的數。
* 例如:
* input[] = {3, 6, 1, 9, 7}
* output[] = {3, 7, 9, 6, 1};
* input[] = {3, 6, 1, 9, 7, 8}
* output[] = {1, 6, 8, 9, 7, 3}
* */
public class TestNewSort {
public static void main(String args[]){
int input[] = {3, 6, 1, 9, 7, 8};
TestNewSort tn = new TestNewSort();
int output[] = tn.getNewSort(input);
for(int i=0; i< output.length; i++){
System.out.print(output[i] + " ");
}
}
public int[] getNewSort(int[] input){
int[] newArr = input;
for(int i=0; i<newArr.length; i++){
for(int j=0; j<newArr.length-1-i; j++){
if(newArr[j]<newArr[j+1]){
int temp = newArr[j];
newArr[j] = newArr[j+1];
newArr[j+1] = temp;
}
}
}
int[] temp = new int[newArr.length];
temp[newArr.length/2] = newArr[0];
int high = newArr.length/2 + 1;
int low = newArr.length/2 - 1;
for(int i=1; i<newArr.length; ){
if(low >=0){//依次將大的元素排在左邊
temp[low] = newArr[i];
low--;
i++;
}
if(high<newArr.length){//依次將第二大的排在右邊
temp[high] = newArr[i];
high++;
i++;
}
}
return temp;
}
}