码迷,mamicode.com
首页 > 编程语言 > 详细

go 算法 查询字符在字符串中的位置

时间:2018-12-03 11:58:30      阅读:281      评论:0      收藏:0      [点我收藏+]

标签:func   ==   sci   for   解答   字符   pos   ipo   判断   

在utf8字符串判断是否包含指定字符串,并返回下标。
"北京天安门最美丽" , "天安门"
结果:2

解答:

import (
    "fmt"
    "strings"
)

func main(){
    fmt.Println(Utf8Index("北京天安门最美丽", "天安门"))
    fmt.Println(strings.Index("北京天安门最美丽", ""))
    fmt.Println(strings.Index("", ""))
    fmt.Println(Utf8Index("12ws北京天安门最美丽", "天安门"))
}

func Utf8Index(str, substr string) int {
    asciiPos := strings.Index(str, substr)
    if asciiPos == -1 || asciiPos == 0 {
        return asciiPos
    }
    pos := 0
    totalSize := 0
    reader := strings.NewReader(str)
    for _, size, err := reader.ReadRune(); err == nil; _, size, err = reader.ReadRune() {
        totalSize += size
        pos++
        // 匹配到
        if totalSize == asciiPos {
            return pos
        }
    }
    return pos
}

 

go 算法 查询字符在字符串中的位置

标签:func   ==   sci   for   解答   字符   pos   ipo   判断   

原文地址:https://www.cnblogs.com/shiluoliming/p/10057563.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!