golang中比較2個slice
阿新 • • 發佈:2019-02-04
這是用雙for的方法實現了2個slice的比較,方法很土,但思路直觀
// FuncTest project main.go package main import ( "fmt" ) //檢查slice b是否在slice a中 //需要比對的2個slice分別是a和b //isSame 比對的2個slice是否相同 //diffSlice 如果2個slice不同,那麼不同的元素將儲存在其中 func checkSliceBInA(a []string, b []string) (isIn bool, diffSlice []string) { lengthA := len(a) for _, valueB := range b { temp := valueB //遍歷取出B中的元素 for j := 0; j < lengthA; j++ { if temp == a[j] { //如果相同 比較下一個 break } else { if lengthA == (j + 1) { //如果不同 檢視a的元素個數及當前比較元素的位置 將不同的元素新增到返回slice中 diffSlice = append(diffSlice, temp) fmt.Println("---->", diffSlice) } } } } if len(diffSlice) == 0 { isIn = true } else { isIn = false } return isIn, diffSlice } func main() { sliceA := []string{"1", "2", "3"} sliceB := []string{"2", "3"} isIn, diffSlice := checkSliceBInA(sliceB, sliceA) fmt.Println(isIn, diffSlice) //輸出 false [1] }
不好的地方在於:
1 2個slice是有順序的,引數順序不一樣結果也不一樣
2 傳入的slice是固定的
網上有人這麼寫func In_slice(val interface{}, slice []interface{}) bool { for _, v := range slice { if v == val { return true } } return false }<pre name="code" class="plain">func Slice_diff(slice1, slice2 []interface{}) (diffslice []interface{}) { for _, v := range slice1 { if !In_slice(v, slice2) { diffslice = append(diffslice, v) } } return }
在gitHub上有人實現了更牛叉的,傳送門https://github.com/fatih/set