結果
問題 | No.201 yukicoderじゃんけん |
ユーザー | gogotea |
提出日時 | 2015-05-03 23:45:44 |
言語 | Go1.4 (1.4.2) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 2,359 bytes |
コンパイル時間 | 457 ms |
コンパイル使用メモリ | 33,792 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-11-25 00:16:44 |
合計ジャッジ時間 | 1,245 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
6,820 KB |
testcase_01 | AC | 1 ms
6,816 KB |
testcase_02 | AC | 1 ms
6,820 KB |
testcase_03 | AC | 1 ms
6,820 KB |
testcase_04 | AC | 1 ms
6,816 KB |
testcase_05 | AC | 1 ms
6,820 KB |
testcase_06 | AC | 1 ms
6,824 KB |
testcase_07 | AC | 1 ms
6,820 KB |
testcase_08 | AC | 1 ms
6,816 KB |
testcase_09 | AC | 1 ms
6,816 KB |
testcase_10 | AC | 1 ms
6,820 KB |
testcase_11 | AC | 1 ms
6,816 KB |
testcase_12 | AC | 1 ms
6,820 KB |
testcase_13 | AC | 1 ms
6,816 KB |
testcase_14 | AC | 1 ms
6,816 KB |
testcase_15 | AC | 2 ms
6,816 KB |
testcase_16 | AC | 2 ms
6,820 KB |
testcase_17 | AC | 2 ms
6,816 KB |
testcase_18 | AC | 1 ms
6,820 KB |
testcase_19 | AC | 2 ms
6,820 KB |
ソースコード
package main import ( "bufio" "fmt" "io" "log" "os" "strconv" ) func main() { es := NewErrScanner(os.Stdin) const numOfPlayers = 2 players := make([]*player, numOfPlayers) for i := 0; i < numOfPlayers; i++ { name := es.Next() points := es.Next() es.Next() players[i] = NewPlayer(name, points) } if es.Err() != nil { log.Fatal(es.Err()) return } fmt.Println(solve(players[0], players[1])) } func solve(a, b *player) string { switch { case len(a.points) > len(b.points): return a.name case len(a.points) < len(b.points): return b.name default: for i := 0; i < len(a.points); i++ { if a.points[i] > b.points[i] { return a.name } if a.points[i] < b.points[i] { return b.name } } return "-1" } } type player struct { name string points string } func NewPlayer(name string, points string) *player { return &player{ name, points, } } type scanner struct { *bufio.Scanner } func NewScanner(r io.Reader) *scanner { return &scanner{ bufio.NewScanner(r), } } func (s *scanner) Next() (string, error) { s.Scanner.Split(bufio.ScanWords) return s.nextToken() } func (s *scanner) NextLine() (string, error) { s.Scanner.Split(bufio.ScanLines) return s.nextToken() } func (s *scanner) nextToken() (string, error) { sc := s.Scanner if sc.Scan() { return sc.Text(), nil } if sc.Err() != nil { return "", sc.Err() } return "", io.EOF } func (s *scanner) NextInt() (int, error) { token, err := s.Next() if err != nil { return 0, err } return strconv.Atoi(token) } func (s *scanner) NextLong() (int64, error) { token, err := s.Next() if err != nil { return 0, err } return strconv.ParseInt(token, 10, 64) } type errScanner struct { sc *scanner err error } func NewErrScanner(r io.Reader) *errScanner { return &errScanner{ sc: NewScanner(r), } } func (e *errScanner) Err() error { return e.err } func (e *errScanner) Next() (token string) { if e.err != nil { return } token, e.err = e.sc.Next() return } func (e *errScanner) NextLine() (line string) { if e.err != nil { return } line, e.err = e.sc.NextLine() return } func (e *errScanner) NextInt() (n int) { if e.err != nil { return } n, e.err = e.sc.NextInt() return } func (e *errScanner) NextLong() (n int64) { if e.err != nil { return } n, e.err = e.sc.NextLong() return }