题解 | #字符串排序#

字符串排序

https://www.nowcoder.com/practice/5190a1db6f4f4ddb92fd9c365c944584

package main

import (
	"bufio"
	"fmt"
	"os"
	"sort"
	"unicode"
)

func main() {
	in := bufio.NewScanner(os.Stdin)
	in.Scan()
	chars := []rune(in.Text())

	var letters []rune
	otherChars := make([]bool, len(chars))
	for i, c := range chars {
		if !unicode.IsLetter(c) {
			otherChars[i] = true
			continue
		}
		letters = append(letters, c)
	}

	sort.SliceStable(letters, func(i, j int) bool {
		return unicode.ToLower(letters[i]) < unicode.ToLower(letters[j])
	})

	for i, c := range chars {
		if otherChars[i] {
			fmt.Printf("%c", c)
			continue
		}
		fmt.Printf("%c", letters[0])
		letters = letters[1:]
	}
}

全部评论

相关推荐

04-28 15:42
郑州大学 C++
找工作勤劳小蜜蜂:网易这几个月在大面积裁员,外包岗全退,今年网易收缩严重,建议慎重考虑网易
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务