需求:給定一個數組和一個正整數,要求把數組分割成多個正整數大小的數組,如果不夠分,則最后一個數組分到剩余的所有元素。
示例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]]
下面是我的實現代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
//分割數組,根據傳入的數組和分割大小,將數組分割為大小等于指定大小的多個數組,如果不夠分,則最后一個數組元素小于其他數組 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實現數組分割的示例代碼的文章就介紹到這了,更多相關golang數組分割 內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/MCJPAO/article/details/108431657