華為上機練習題--按照新規則排序

來源:互聯網
上載者:User

標籤: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;
    }
}


相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.