package main import ( "bufio" "fmt" "os" ) func main() { s := readLine() sRune := []rune(s) n := make([]rune, len(sRune)) max := s for i := 0; i < len(s)-1; i++ { for j := i; j < len(s); j++ { n[i], n[j] = n[j], n[i] if max < string(n){ max = string(n) } n[j], n[i] = n[i], n[j] } } fmt.Println(max) } var rdr = bufio.NewReaderSize(os.Stdin, 1000000) func readLine() string { buf := make([]byte, 0, 1000000) for { l, p, e := rdr.ReadLine() if e != nil { panic(e) } buf = append(buf, l...) if !p { break } } return string(buf) }