为了账号安全,请及时绑定邮箱和手机立即绑定

是否可以使用按位运算在随机 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 关注
  • 128 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号