精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

數據結構與算法之按奇偶排序數組II

開發 前端 算法
一道簡單模擬題,來做做看!給定一個非負整數數組 A, A 中一半整數是奇數,一半整數是偶數。對數組進行排序,以便當 A[i] 為奇數時,i 也是奇數;當 A[i] 為偶數時, i 也是偶數。

[[429517]]

一道簡單模擬題,來做做看!

按奇偶排序數組II

力扣題目鏈接:https://leetcode-cn.com/problems/sort-array-by-parity-ii/

給定一個非負整數數組 A, A 中一半整數是奇數,一半整數是偶數。

對數組進行排序,以便當 A[i] 為奇數時,i 也是奇數;當 A[i] 為偶數時, i 也是偶數。

你可以返回任何滿足上述條件的數組作為答案。

示例:

  • 輸入:[4,2,5,7]
  • 輸出:[4,5,2,7]
  • 解釋:[4,7,2,5],[2,5,4,7],[2,7,4,5] 也會被接受。

思路

這道題目直接的想法可能是兩層for循環再加上used數組表示使用過的元素。這樣的的時間復雜度是O(n^2)。

方法一

其實這道題可以用很樸實的方法,時間復雜度就就是O(n)了,C++代碼如下:

  1. class Solution { 
  2. public
  3.     vector<int> sortArrayByParityII(vector<int>& A) { 
  4.         vector<int> even(A.size() / 2); // 初始化就確定數組大小,節省開銷 
  5.         vector<int> odd(A.size() / 2); 
  6.         vector<int> result(A.size()); 
  7.         int evenIndex = 0; 
  8.         int oddIndex = 0; 
  9.         int resultIndex = 0; 
  10.         // 把A數組放進偶數數組,和奇數數組 
  11.         for (int i = 0; i < A.size(); i++) { 
  12.             if (A[i] % 2 == 0) even[evenIndex++] = A[i]; 
  13.             else odd[oddIndex++] = A[i]; 
  14.         } 
  15.         // 把偶數數組,奇數數組分別放進result數組中 
  16.         for (int i = 0; i < evenIndex; i++) { 
  17.             result[resultIndex++] = even[i]; 
  18.             result[resultIndex++] = odd[i]; 
  19.         } 
  20.         return result; 
  21.     } 
  22. }; 
  • 時間復雜度:O(n)
  • 空間復雜度:O(n)

方法二

以上代碼我是建了兩個輔助數組,而且A數組還相當于遍歷了兩次,用輔助數組的好處就是思路清晰,優化一下就是不用這兩個輔助樹,代碼如下:

  1. class Solution { 
  2. public
  3.     vector<int> sortArrayByParityII(vector<int>& A) { 
  4.         vector<int> result(A.size()); 
  5.         int evenIndex = 0;  // 偶數下表 
  6.         int oddIndex = 1;   // 奇數下表 
  7.         for (int i = 0; i < A.size(); i++) { 
  8.             if (A[i] % 2 == 0) { 
  9.                 result[evenIndex] = A[i]; 
  10.                 evenIndex += 2; 
  11.             } 
  12.             else { 
  13.                 result[oddIndex] = A[i]; 
  14.                 oddIndex += 2; 
  15.             } 
  16.         } 
  17.         return result; 
  18.     } 
  19. }; 
  • 時間復雜度O(n)
  • 空間復雜度O(n)

方法三

當然還可以在原數組上修改,連result數組都不用了。

  1. class Solution { 
  2. public
  3.     vector<int> sortArrayByParityII(vector<int>& A) { 
  4.         int oddIndex = 1; 
  5.         for (int i = 0; i < A.size(); i += 2) { 
  6.             if (A[i] % 2 == 1) { // 在偶數位遇到了奇數 
  7.                 while(A[oddIndex] % 2 != 0) oddIndex += 2; // 在奇數位找一個偶數 
  8.                 swap(A[i], A[oddIndex]); // 替換 
  9.             } 
  10.         } 
  11.         return A; 
  12.     } 
  13. }; 
  • 時間復雜度:O(n)
  • 空間復雜度:O(1)

這里時間復雜度并不是O(n^2),因為偶數位和奇數位都只操作一次,不是n/2 * n/2的關系,而是n/2 + n/2的關系!

其他語言版本

Java

  1. // 方法一 
  2. class Solution { 
  3.     public int[] sortArrayByParityII(int[] nums) { 
  4.         // 分別存放 nums 中的奇數、偶數 
  5.         int len = nums.length; 
  6.         int evenIndex = 0; 
  7.         int oddIndex = 0; 
  8.         int[] even = new int[len / 2]; 
  9.         int[] odd = new int[len / 2]; 
  10.         for (int i = 0; i < len; i++) { 
  11.             if (nums[i] % 2 == 0) { 
  12.                 even[evenIndex++] = nums[i]; 
  13.             } else { 
  14.                 odd[oddIndex++] = nums[i]; 
  15.             } 
  16.         } 
  17.         // 把奇偶數組重新存回 nums 
  18.         int index = 0; 
  19.         for (int i = 0; i < even.length; i++) { 
  20.             nums[index++] = even[i]; 
  21.             nums[index++] = odd[i]; 
  22.         } 
  23.         return nums; 
  24.     } 

Python3

  1. #方法2 
  2. class Solution: 
  3.     def sortArrayByParityII(self, nums: List[int]) -> List[int]: 
  4.         result = [0]*len(nums) 
  5.         evenIndex = 0 
  6.         oddIndex = 1 
  7.         for i in range(len(nums)): 
  8.             if nums[i] % 2: #奇數 
  9.                 result[oddIndex] = nums[i] 
  10.                 oddIndex += 2 
  11.             else: #偶數 
  12.                 result[evenIndex] = nums[i] 
  13.                 evenIndex += 2 
  14.         return result 
  15.  
  16. #方法3 
  17. class Solution: 
  18.     def sortArrayByParityII(self, nums: List[int]) -> List[int]: 
  19.         oddIndex = 1 
  20.         for i in range(0,len(nums),2): #步長為2 
  21.             if nums[i] % 2: #偶數位遇到奇數 
  22.                 while  nums[oddIndex] % 2: #奇數位找偶數 
  23.                     oddIndex += 2 
  24.                 nums[i], nums[oddIndex] = nums[oddIndex], nums[i] 
  25.         return nums 

Go

  1. // 方法一 
  2. func sortArrayByParityII(nums []int) []int { 
  3.  // 分別存放 nums 中的奇數、偶數 
  4.  even, odd := []int{}, []int{} 
  5.  for i := 0; i < len(nums); i++ { 
  6.   if (nums[i] % 2 == 0) { 
  7.    even = append(even, nums[i]) 
  8.   } else { 
  9.    odd = append(odd, nums[i]) 
  10.   } 
  11.  } 
  12.  
  13.  // 把奇偶數組重新存回 nums 
  14.  result := make([]int, len(nums)) 
  15.  index := 0 
  16.  for i := 0; i < len(even); i++ { 
  17.   result[index] = even[i]; index++; 
  18.   result[index] = odd[i]; index++; 
  19.  } 
  20.  return result; 

JavaScript

  1. //方法一 
  2. var sortArrayByParityII = function(nums) { 
  3.     const n = nums.length; 
  4.     // 分別存放 nums 中的奇數、偶數 
  5.     let evenIndex = 0, oddIndex = 0; 
  6.     // 初始化就確定數組大小,節省開銷 
  7.     const even = new Array(Math.floor(n/2)); 
  8.     const odd = new Array(Math.floor(n/2)); 
  9.     // 把A數組放進偶數數組,和奇數數組 
  10.     for(let i = 0; i < n; i++){ 
  11.         if(nums[i] % 2 === 0) even[evenIndex++] = nums[i]; 
  12.         else odd[oddIndex++] = nums[i]; 
  13.     } 
  14.     // 把奇偶數組重新存回 nums 
  15.     let index = 0; 
  16.     for(let i = 0; i < even.length; i++){ 
  17.         nums[index++] = even[i]; 
  18.         nums[index++] = odd[i]; 
  19.     } 
  20.     return nums; 
  21. }; 
  22.  
  23. //方法二 
  24. var sortArrayByParityII = function(nums) { 
  25.     const n = nums.length; 
  26.     const result = new Array(n); 
  27.     // 偶數下標 和 奇數下標 
  28.     let evenIndex = 0, oddIndex = 1; 
  29.     for(let i = 0; i < n; i++){ 
  30.         if(nums[i] % 2 === 0) { 
  31.             result[evenIndex] = nums[i]; 
  32.             evenIndex += 2; 
  33.         } else { 
  34.             result[oddIndex] = nums[i]; 
  35.             oddIndex += 2; 
  36.         } 
  37.     } 
  38.     return result; 
  39. }; 
  40.  
  41. //方法三 
  42. var sortArrayByParityII = function(nums) { 
  43.     let oddIndex = 1; 
  44.     for(let i = 0; i < nums.length; i += 2){ 
  45.         if(nums[i] % 2 === 1){ // 在偶數位遇到了奇數 
  46.             while(nums[oddIndex] % 2 !== 0) oddIndex += 2;// 在奇數位找一個偶數 
  47.             [nums[oddIndex], nums[i]] = [nums[i], nums[oddIndex]]; // 解構賦值交換 
  48.         } 
  49.     } 
  50.     return nums; 
  51. }; 

 

責任編輯:姜華 來源: 代碼隨想錄
相關推薦

2023-03-07 08:02:07

數據結構算法數列

2023-03-02 08:15:13

2023-03-10 08:07:39

數據結構算法計數排序

2021-07-16 04:57:45

Go算法結構

2022-01-18 19:13:52

背包問題數據結構算法

2023-04-27 09:13:20

排序算法數據結構

2023-03-13 10:08:31

數據結構算法

2019-03-29 09:40:38

數據結構算法前端

2023-03-06 08:10:52

數據結構算法數據

2021-04-15 09:36:44

Java數據結構算法

2021-03-23 08:33:22

Java數據結構算法

2022-09-26 07:56:53

AVL算法二叉樹

2022-09-21 07:57:33

二叉搜索樹排序二叉樹

2020-10-30 09:56:59

Trie樹之美

2020-10-21 14:57:04

數據結構算法圖形

2020-12-31 05:31:01

數據結構算法

2023-03-08 08:03:09

數據結構算法歸并排序

2017-06-16 09:22:22

數據結構算法鏈表

2021-03-08 06:28:57

JAVA數據結構與算法稀疏數組

2020-10-20 08:14:08

算法與數據結構
點贊
收藏

51CTO技術棧公眾號

国内自拍第二页| 国产欧美精品一区二区三区| 国产一级久久久久毛片精品| 日韩毛片一区| 亚洲视频免费观看| 精品欧美一区二区久久久伦| 中文字幕亚洲乱码熟女1区2区| 精品久久久久中文字幕小说| 欧美一区日本一区韩国一区| 久久美女福利视频| 亚洲wwwww| 国产视频一区在线播放| 成人信息集中地欧美| 天堂资源在线播放| 色呦哟—国产精品| 亚洲国产91色在线| 国产福利在线免费| 麻豆免费在线| 亚洲精品视频在线| 婷婷久久伊人| 色窝窝无码一区二区三区| 蜜臀av性久久久久蜜臀av麻豆| 欧美日韩第一页| 男人的天堂av网| 久久超级碰碰| 欧美一级欧美一级在线播放| 欧美黄色一级片视频| 性欧美ⅴideo另类hd| 日本一区二区三区免费乱视频 | 成人黄色在线看| 国产日韩精品一区二区| 可以免费在线观看的av| 亚洲欧美偷拍自拍| 中文字幕av一区二区| 色噜噜在线观看| 日韩在线观看一区二区三区| 欧美视频精品在线观看| 人妻av中文系列| a级网站在线播放| 国产欧美一区二区精品性| 国产精品区一区二区三含羞草| 夜夜爽8888| 久久久久久黄| 5566日本婷婷色中文字幕97| 国产一级特黄a高潮片| 亚洲综合小说| 精品国内亚洲在观看18黄| 欧美黄色激情视频| 免费不卡中文字幕在线| 国产丝袜精品第一页| 国产大学生视频| 999精品视频在这里| 日韩一区和二区| 亚洲AV无码久久精品国产一区| 成人不卡视频| 欧美日韩一区二区三区高清| 日韩免费高清在线| 户外露出一区二区三区| 欧美日韩一区二区在线| 日本www在线视频| 美女av在线免费看| 黑人极品videos精品欧美裸| 自拍日韩亚洲一区在线| 欧美男人天堂| 色噜噜狠狠成人中文综合| 国产精品人人妻人人爽人人牛| 少妇视频一区| 在线精品亚洲一区二区不卡| 成人免费无码av| 精品三区视频| 欧美精品日韩精品| 91丨porny丨九色| 国产伦乱精品| 精品一区二区三区三区| 日韩乱码人妻无码中文字幕久久 | 亚洲自拍三区| 操你啦视频在线| 一区二区三区成人| 国产真人做爰毛片视频直播 | 一区二区三区在线观看网站| 久久精品在线免费视频| 精品精品导航| 日韩欧美精品网站| 在线观看免费成人av| 美女视频一区| 欧美精品一区二区久久婷婷 | 久久99精品久久久久久欧洲站| 精品亚洲一区二区三区| 国产传媒在线看| 欧美人成在线| 人人澡人人澡人人看欧美| 在线永久看片免费的视频| 免费在线看成人av| y111111国产精品久久婷婷| 日本波多野结衣在线| 26uuu色噜噜精品一区| 亚洲视频sss| 五月天激情在线| 欧美视频不卡中文| 亚洲一区精品视频在线观看| 99国产精品久久一区二区三区| 日韩精品999| 黄色片子在线观看| 国产精品普通话对白| 国产精品午夜一区二区欲梦| 亚洲av无码一区二区乱子伦| 国产欧美综合在线观看第十页| 日本女人高潮视频| xxxxx性欧美特大| 91精品国产aⅴ一区二区| 国产乱了高清露脸对白| 欧美oldwomenvideos| 久久久久日韩精品久久久男男 | 国产激情视频在线观看| 天天爽夜夜爽夜夜爽精品视频| www.超碰97.com| 欧美精品中文| 欧美不卡视频一区发布| 手机看片久久久| 丁香激情综合国产| 欧美 日韩 国产 在线观看 | 欧美性69xxxx肥| 少妇熟女视频一区二区三区 | 99视频精品在线| 艳母动漫在线免费观看| 黄色亚洲网站| 精品999久久久| www.97视频| 日本在线观看不卡视频| 久久资源av| av2020不卡| 日韩欧美的一区| www.97视频| 久久精品999| 日韩精品不卡| 日本综合字幕| 国产丝袜精品第一页| 日韩精品――中文字幕| 国产suv精品一区二区6| 欧美h视频在线观看| 69堂免费精品视频在线播放| 亚洲免费电影一区| 草久视频在线观看| 91丨porny丨国产入口| 丁香六月激情婷婷| swag国产精品一区二区| 色综合久久88| 成 人 黄 色 片 在线播放| 1000精品久久久久久久久| 日韩欧美国产片| 日韩av有码| 国产精品视频久久| 天堂地址在线www| 欧美日韩一区二区三区高清 | 一区二区三区精品视频| √天堂资源在线| 欧美1区视频| 99在线高清视频在线播放| av免费在线观看网址| 日韩午夜电影在线观看| 久久国产精品波多野结衣av| 国产不卡在线一区| 给我免费播放片在线观看| 国产精品宾馆| 欧美一区二区三区四区在线| 久久精品国产亚洲a∨麻豆| 在线观看免费亚洲| 国产亚洲精品久久久久久豆腐| 韩国欧美国产1区| 成人污网站在线观看| 99精品国产一区二区三区2021 | 成人a在线观看高清电影| 最新亚洲国产精品| 国产乱码久久久| 亚洲国产精品嫩草影院| 欧美 日本 国产| 日本女人一区二区三区| 中国一区二区三区| 高清日韩中文字幕| 欧美最顶级的aⅴ艳星| 大地资源中文在线观看免费版| 欧美嫩在线观看| 久久免费精彩视频| 久久精品视频一区二区三区| 深夜黄色小视频| 欧美91福利在线观看| 久久av一区二区三区亚洲| 日本欧美韩国| 欧美另类暴力丝袜| 天堂影院在线| 欧美精品自拍偷拍动漫精品| 久久久久久福利| 国产色产综合产在线视频| 色综合五月婷婷| 一二三区精品| 中文字幕在线亚洲精品| 另类在线视频| 成人黄色免费片| 免费在线小视频| 久久精品国产2020观看福利| 国产综合在线播放| 欧美日韩在线一区二区| 日本少妇在线观看| 国产精品久久久久7777按摩| 在线观看免费视频国产| 男女男精品视频| 欧美极品欧美精品欧美| 国产精品成人a在线观看| 精品91免费| 奇米一区二区| 国产精品视频久| 成年美女黄网站色大片不卡| 欧美另类99xxxxx| 日本不卡三区| 亚洲人成电影在线观看天堂色| 亚洲av色香蕉一区二区三区| 欧美在线看片a免费观看| 日本一区二区不卡在线| 亚洲女人小视频在线观看| www在线观看免费视频| 成人午夜电影小说| 日本高清免费观看| 久久精品噜噜噜成人av农村| 国产免费毛卡片| 亚洲午夜久久久久久尤物| 综合操久久久| 国产亚洲电影| 狠狠色综合网站久久久久久久| 国产精品成人3p一区二区三区| 国产精品欧美久久久| 不卡一二三区| 7777kkkk成人观看| gogo高清午夜人体在线| 欧美日本高清视频| 3d玉蒲团在线观看| 久久影视免费观看| 欧美尤物美女在线| 丝袜情趣国产精品| eeuss影院在线播放| 亚洲视频在线看| 久草在线青青草| 亚洲三级av在线| 国产一二三在线观看| 亚洲欧洲在线免费| 国产女人在线视频| 亚洲图片在线综合| 风间由美一区| 综合国产在线视频| 日本在线观看网站| 色偷偷9999www| 黄色免费在线观看| 欧美成人免费va影院高清| 免费高清完整在线观看| 精品国产欧美成人夜夜嗨| 在线播放麻豆| 久久国内精品一国内精品| 免费大片黄在线观看视频网站| 日韩中文字幕网| 久久99精品久久久久久野外| 久色乳综合思思在线视频| 中文字幕伦理免费在线视频| 色综合色综合网色综合| 欧美大片黄色| 欧美有码在线观看视频| 日韩一区二区三区免费| 91精品国产自产在线观看永久| 国产精品免费精品自在线观看| 91在线|亚洲| 国产极品模特精品一二| 久久综合毛片| 欧美色女视频| 国产免费xxx| 亚洲激情在线| 亚洲少妇第一页| 黄色小说综合网站| 黄色性视频网站| 久久精品一级爱片| 顶级黑人搡bbw搡bbbb搡| 成人欧美一区二区三区黑人麻豆| 欧美精品久久久久性色| 欧美日韩国产精品一区二区三区四区 | 91精品国产高清自在线| 国产日韩电影| 91精品国产综合久久香蕉922| 欧美成人精品午夜一区二区| 国产日韩精品一区观看| 精品久久电影| 久青草视频在线播放| 久久国产66| 波多野结衣网页| 久久久777精品电影网影网| 三上悠亚在线观看视频| 亚洲国产综合人成综合网站| 国产成人无码一区二区在线播放| 欧美日韩情趣电影| 免费成人在线看| 一区二区三区日韩在线| 久久青青色综合| 国产精品视频内| 嗯用力啊快一点好舒服小柔久久| 欧美三日本三级少妇三99| 亚洲经典一区| 日本在线视频www| 国产馆精品极品| 国产一区二区三区精品在线| 亚洲一区二区三区三| 中文字幕人妻丝袜乱一区三区| 精品国一区二区三区| 色多多视频在线观看| 2021久久精品国产99国产精品| 国产免费区一区二区三视频免费| 久久久影院一区二区三区| 欧美在线二区| 中文字幕亚洲乱码| 久久综合九色欧美综合狠狠| 欧美偷拍第一页| 精品视频一区二区不卡| 亚洲三级黄色片| 欧美高清无遮挡| 四虎视频在线精品免费网址| 欧美日韩精品免费观看| 亚洲国产激情| 26uuu国产| 亚洲少妇最新在线视频| 欧美视频xxxx| 亚洲图片在区色| 综合另类专区| 精品产品国产在线不卡| 欧美激情一级片一区二区| 日韩欧美国产片| 欧美国产一区在线| 9i看片成人免费看片| 亚洲国产成人av在线| 伊人电影在线观看| 2014国产精品| 欧美一区高清| 国模大尺度视频| 亚洲激情中文1区| 国产美女三级无套内谢| 日韩中文综合网| 亚洲国产aⅴ精品一区二区三区| 日韩黄色影视| 免费人成在线不卡| 九一在线免费观看| 欧美网站一区二区| 高h视频在线| 国产精品久久久久免费a∨大胸| 国产传媒欧美日韩成人精品大片| 亚洲爆乳无码专区| 久久网站最新地址| 成人毛片一区二区三区| 伊人青青综合网站| 国产亚洲精彩久久| 中文精品一区二区三区 | 国产精品久久久久久久天堂| 你微笑时很美电视剧整集高清不卡| 欧美亚洲国产成人| 国产亚洲女人久久久久毛片| 最新中文字幕免费| 久久精品久久久久| 日本少妇精品亚洲第一区| 日本福利视频网站| 99久久精品国产网站| 一区二区三区福利视频| 亚洲欧洲一区二区三区在线观看 | 里番在线观看网站| 亚洲自拍偷拍视频| 怡红院精品视频在线观看极品| 中文成人无字幕乱码精品区| 欧美视频在线免费看| 国产视频精品久久| 国产日产久久高清欧美一区| 91精品亚洲| 亚洲激情 欧美| 色综合久久综合网欧美综合网| 大片免费播放在线视频| 亚洲999一在线观看www| 今天的高清视频免费播放成人| 黄色a一级视频| 欧美日韩在线播放一区| 伊人影院蕉久影院在线播放| 就去色蜜桃综合| 麻豆精品一区二区| 国产精品30p| 亚洲偷欧美偷国内偷| 精品一区二区三区中文字幕视频 | 日本成人中文字幕在线视频| 性欧美疯狂猛交69hd| 亚洲国产天堂久久国产91 | 一二三不卡视频| 欧美日韩久久一区| 国产精品一二三产区| 亚洲一区3d动漫同人无遮挡 | 高清视频一区| 日韩专区在线视频| 中文字幕在线有码| 亚洲四色影视在线观看| 日韩一区二区三区高清在线观看| 国产无套内射久久久国产| 亚洲免费av观看|