結果
問題 | No.123 カードシャッフル |
ユーザー |
![]() |
提出日時 | 2015-04-27 19:44:49 |
言語 | Go1.4 (1.4.2) |
結果 |
AC
|
実行時間 | 25 ms / 5,000 ms |
コード長 | 1,130 bytes |
コンパイル時間 | 278 ms |
コンパイル使用メモリ | 34,896 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-25 00:13:31 |
合計ジャッジ時間 | 1,143 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 10 |
ソースコード
package mainimport ("bufio""container/list""fmt""io""os""strconv")func main() {sc := NewScanner(os.Stdin)N, _ := sc.NextInt()M, _ := sc.NextInt()l := list.New()for i := 1; i <= N; i++ {l.PushBack(i)}for i := 1; i <= M; i++ {A, _ := sc.NextInt()e := getElement(l, A)l.MoveToFront(e)}fmt.Println(l.Front().Value)}func getElement(l *list.List, n int) (elem *list.Element) {if n <= 0 || n > l.Len() {return nil}var i int = 1for elem = l.Front(); elem != nil; elem = elem.Next() {if i == n {break}i++}return elem}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.Scannerif 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)}