結果
問題 |
No.927 Second Permutation
|
ユーザー |
![]() |
提出日時 | 2019-12-12 23:10:46 |
言語 | Go (1.23.4) |
結果 |
WA
|
実行時間 | - |
コード長 | 702 bytes |
コンパイル時間 | 12,914 ms |
コンパイル使用メモリ | 231,612 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-25 21:45:06 |
合計ジャッジ時間 | 14,376 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 10 WA * 17 |
ソースコード
package main import ( "bufio" "fmt" "os" "sort" "strings" ) func main() { stdin := bufio.NewScanner(os.Stdin) stdin.Split(bufio.ScanWords) x := read(stdin) chars := strings.Split(x, "") sort.Strings(chars) ok := false for i := 1; i < len(chars); i++ { if chars[0] != chars[i] { chars[0], chars[i] = chars[i], chars[0] ok = true break } } if ok { var sb strings.Builder for i := len(chars) - 1; i >= 0; i-- { sb.WriteString(chars[i]) } y := sb.String() if x == y || strings.HasPrefix(y, "0") { fmt.Println(-1) } else { fmt.Println(y) } } else { fmt.Println(-1) } } func read(stdin *bufio.Scanner) string { stdin.Scan() return stdin.Text() }