亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

是否可以使用按位運算在隨機 unicode 字符串中找到重復字符?

是否可以使用按位運算在隨機 unicode 字符串中找到重復字符?

Go
Helenr 2022-12-19 11:57:43
我一直在尋找一種解決方案來查找字符串中的重復字符,并且我對按位運算的解決方案很感興趣。我發現了這樣一個按位運算的變體。但在其中,搜索發生在 ASCII 表的 az 范圍內。func HasDuplicates(str string) (string, bool) {    checker := 0    for _, char := range str {        val := char - 'a'        fmt.Println(val)        if (checker & (1 << val)) > 0 {            fmt.Printf("'%c' is Duplicate\n", char)            return str, false        }        checker |= 1 << val    }    return str, true}是否有可能像上面的例子一樣,只針對隨機的 unicode 字符串(象形文字、表情符號等)制定一個通用的解決方案?
查看完整描述

1 回答

?
SMILET

TA貢獻1796條經驗 獲得超4個贊

使用big.Int作為位集:

func HasDuplicates(str string) (string, bool) {

    var bits big.Int

    for _, char := range str {

        val := int(char)

        fmt.Println(val)

        if bits.Bit(val) != 0 {

            fmt.Printf("'%c' is Duplicate\n", char)

            return str, false

        }

        bits.SetBit(&bits, val, 1)

    }

    return str, true

}

https://go.dev/play/p/kS-OxYPts5G


這有多有效將取決于 big.Int 的實現,您無法像在簡單整數上使用按位運算那樣控制它。


您還可以使用布爾值映射,盡管那樣它就不再是按位運算了:


func HasDuplicates(str string) (string, bool) {

    var bits = make(map[int]bool)

    for _, char := range str {

        val := int(char)

        fmt.Println(val)

        if bits[val] {

            fmt.Printf("'%c' is Duplicate\n", char)

            return str, false

        }

        bits[val] = true

    }

    return str, true

}


查看完整回答
反對 回復 2022-12-19
  • 1 回答
  • 0 關注
  • 109 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號