結果
問題 | No.156 キャンディー・ボックス |
ユーザー |
![]() |
提出日時 | 2015-04-28 22:37:50 |
言語 | Go1.4 (1.4.2) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 967 bytes |
コンパイル時間 | 2,693 ms |
コンパイル使用メモリ | 33,152 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-05 09:14:58 |
合計ジャッジ時間 | 3,542 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 30 |
ソースコード
package main import ( "bufio" "fmt" "io" "os" "sort" "strconv" ) func main() { sc := NewScanner(os.Stdin) N, _ := sc.NextInt() M, _ := sc.NextInt() C := make([]int, N) for i := 0; i < N; i++ { C[i], _ = sc.NextInt() } fmt.Println(Solve(C, M)) } func Solve(box []int, m int) int { count := 0 sort.Ints(box) for _, v := range box { if m <= 0 || v > m { break } count++ m -= v } return count } 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) 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) }