給你一個整數數組 nums,請你將該數組升序排列。數組
示例 1:網絡
輸入:nums = [5,2,3,1]
輸出:[1,2,3,5]
示例 2:函數
輸入:nums = [5,1,1,2,0,0]
輸出:[0,0,1,1,2,5]編碼
方法1spa
利用sort方法進行排序,最佳code
/** * @param {number[]} nums * @return {number[]} */ var sortArray = function(nums) { return nums.sort((a,b)=>{return a-b}); };
數組.sort(參數)blog
方法用於對數組的元素進行排序。排序
沒有使用參數,將按字母順序對數組中的元素進行排序,說得更精確點,是按照字符編碼的順序進行排序。要實現這一點,首先應把數組的元素都轉換成字符串(若有必要),以便進行比較。遞歸
若是想按照其餘標準進行排序,就須要提供比較函數,該函數要比較兩個值,而後返回一個用於說明這兩個值的相對順序的數字。比較函數應該具備兩個參數 a 和 b,其返回值以下:內存
方法2
快速排序
選一個參照數target,對比每一項和target的大小,大於target放在right數組,小於target放在left數組,遞歸對比,獲得最後分別排好序的left,right兩個數組,再將target拼接上去,就獲得了排序好的數組
不適用數組數量特別大的時候 會報錯 Maximum call stack size exceeded 內存溢出
var sortArray = function(nums) { if(nums.length<2) return nums; var target=nums[0]; var left=[],right=[]; for(var i=1;i<nums.length;i++){ if(nums[i]<target){ left.push(nums[i]) }else{ right.push(nums[i]) } } return sortArray(left).concat([target],sortArray(right)) };
方法3
冒泡排序
對比相鄰兩個位置的大小,0和1對比,1再次和2相比,最終length-1次得出最後的順序;length-1次的時候會比較length-1和length的大小
var sortArray = function(nums) { for(var i=0;i<nums.length-1;i++){ for(var j=0;j<nums.length-1-i;j++){ if(nums[j]>nums[j+1]){ var target=nums[j]; nums[j]=nums[j+1] nums[j+1]=target } } } return nums; };
來源:力扣(LeetCode)連接:https://leetcode-cn.com/problems/sort-an-array著做權歸領釦網絡全部。商業轉載請聯繫官方受權,非商業轉載請註明出處。