結果

問題 No.275 中央値を求めよ
コンテスト
ユーザー yusaka
提出日時 2015-09-22 05:37:07
言語 Scheme
(Gauche-0.9.15)
コンパイル:
true
実行:
gosh _filename_
結果
AC  
実行時間 89 ms / 1,000 ms
コード長 885 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 39 ms
コンパイル使用メモリ 7,716 KB
実行使用メモリ 35,148 KB
最終ジャッジ日時 2026-03-11 03:27:50
合計ジャッジ時間 3,319 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 38
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#!/usr/bin/env gosh
(define (read-input)
  (let ((n (read (open-input-string (read-line))))
        (numbers (read (open-input-string (string-append "(" (read-line) ")")))))
    (cons n numbers)))

(define (sort lst)
  (define (filter p? lst acc)
    (if (null? lst)
        acc
        (if (p? (car lst))
            (filter p? (cdr lst) (cons (car lst) acc))
            (filter p? (cdr lst) acc))))
  (if (null? lst)
      '()
      (append (sort (filter (lambda (x) (<= (car lst) x)) (cdr lst) '()))
              (list (car lst))
              (sort (filter (lambda (x) (> (car lst) x)) (cdr lst) '())))))

(define (get-median lst)
  (let ((n (car lst))
        (ns (sort (cdr lst))))
    (if (even? n)
        (* 0.5
           (+ (list-ref ns (/ n 2))
              (list-ref ns (- (/ n 2) 1))))
        (list-ref ns (div n 2)))))

(display (get-median (read-input)))
(newline)
0