教你如何運用golang實現陣列分割

大雄45發表於2022-03-05
導讀 本文主要介紹了golang實現陣列分割的示例程式碼,要求把陣列分割成多個正整數大小的陣列,文中透過示例程式碼介紹的非常詳細,具有一定的參考價值,感興趣的小夥伴們可以參考一下

需求:給定一個陣列和一個正整數,要求把陣列分割成多個正整數大小的陣列,如果不夠分,則最後一個陣列分到剩餘的所有元素。

示例1:

陣列:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10],正整數:2
期望結果: [[1, 2], [3, 4], [5, 6], [7, 8], [9, 10]]

示例2:

陣列:[1, 2, 3, 4, 5, 6, 7, 8, 9],正整數:2
期望結果: [[1, 2], [3, 4], [5, 6], [7, 8], [9]]

下面是我的實現程式碼:

//分割陣列,根據傳入的陣列和分割大小,將陣列分割為大小等於指定大小的多個陣列,如果不夠分,則最後一個陣列元素小於其他陣列
func splitArray(arr []int, num int64) [][]int {
 max := int64(len(arr))
 //判斷陣列大小是否小於等於指定分割大小的值,是則把原陣列放入二維陣列返回
 if max <= num {
  return [][]int{arr}
 }
 //獲取應該陣列分割為多少份
 var quantity int64
 if max%num == 0 {
  quantity = max / num
 } else {
  quantity = (max / num) + 1
 }
 //宣告分割好的二維陣列
 var segments = make([][]int, 0)
 //宣告分割陣列的截止下標
 var start, end, i int64
 for i = 1; i <= quantity; i++ {
  end = i*num
  if i != quantity {
   segments = append(segments, arr[start:end])
  } else {
   segments = append(segments, arr[start:])
  }
  start = i*num
 }
 return segments
}

附:這個是我在實際業務需求中遇到的問題,不知道大家有沒有更好寫法

到此這篇關於golang實現陣列分割的示例程式碼的文章就介紹到這了

原文來自:

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2855481/,如需轉載,請註明出處,否則將追究法律責任。

相關文章