golang 切片去重

方法一 雙重for循環(huán),設(shè)置標(biāo)識(shí),增加到新的切片中,達(dá)到去重效果:

func main() {
    var arr = []string{"hello", "hi", "world", "hi", "china", "hello", "hi"}
    fmt.Println(RemoveRepeatedElement(arr))
}
func RemoveRepeatedElement(arr []string) (newArr []string) {
    newArr = make([]string, 0)
    for i := 0; i < len(arr); i++ {
        repeat := false
        for j := i + 1; j < len(arr); j++ {
            if arr[i] == arr[j] {
                repeat = true
                break
            }
        }
        if !repeat {
            newArr = append(newArr, arr[i])
        }
    }
    return
}

方法二: 通過map鍵的唯一性去重

//第二種寫法:更簡(jiǎn)潔點(diǎn)
func RemoveRepeated(s []int) []int {
    start := time.Now()
    result := []int{}
    m := make(map[int]bool) //map的值不重要
    for _, v := range s {
        if _, ok := m[v]; !ok {
            result = append(result, v)
            m[v] = true
        }
    }
    fmt.Println("花費(fèi)時(shí)間:", fmt.Sprintf("%vms", (time.Now().UnixNano()-start.UnixNano())/1e+6))
    return result
}

//第二種寫法: 
var strMap make(map[string]string)
strSlice := []string {"slice","int","string","int","boolean","string"}
for _,v:= range strSlice{
    strMap[v] = v
}
//strMap為:{"slice":"slice","int":"int","string":"string","boolean":boolean"}
//如果想將map轉(zhuǎn)換為slice,可利用數(shù)組的append函數(shù)
var secondStr []string
for _,value := range strMap{
    secondStr = append(secondStr ,value)
}
//secondStr為:{"slice","int","string","boolean"}

方法三:利用反射和interface實(shí)現(xiàn), 我有點(diǎn)看不懂

func main() {
  b := []string{"a", "b", "c", "c", "e", "f", "a", "g", "b", "b", "c"}
   sort.Strings(b)
   fmt.Println(Duplicate(b))
   c := []int{1, 1, 2, 4, 6, 7, 8, 4, 3, 2, 5, 6, 6, 8}
   sort.Ints(c)
   fmt.Println(Duplicate(c))
}
func Duplicate(a interface{}) (ret []interface{}) {
   va := reflect.ValueOf(a)
   for i := 0; i < va.Len(); i++ {
      if i > 0 && reflect.DeepEqual(va.Index(i-1).Interface(), va.Index(i).Interface()) {
         continue
      }
      ret = append(ret, va.Index(i).Interface())
   }
   return ret
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容