結果
問題 |
No.885 アマリクエリ
|
ユーザー |
|
提出日時 | 2019-09-29 02:04:00 |
言語 | Scheme (Gauche-0.9.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,255 bytes |
コンパイル時間 | 41 ms |
コンパイル使用メモリ | 6,944 KB |
実行使用メモリ | 79,840 KB |
最終ジャッジ日時 | 2024-10-03 04:22:23 |
合計ジャッジ時間 | 6,588 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | -- * 3 |
other | TLE * 1 -- * 18 |
ソースコード
;;; File: main.scm ;; Author: ymiyamoto ;; ;; Created on Sun Sep 29 01:12:58 2019 ;; (define-syntax read-number (syntax-rules () ((_ nums) (define-values nums (apply values (map string->number (string-split (read-line) #\space))))))) (define-syntax read-numbers (syntax-rules () ((_ as) (define as (map string->number (string-split (read-line) #\space)))) ((_ as n) (define as (map (lambda (_) (map string->number (string-split (read-line) #\space))) (iota n)))))) (define-syntax prlist (syntax-rules () ((_ lis) (print (string-join (map number->string lis) " "))))) (define-syntax 1+ (syntax-rules () ((_ x) (+ x 1)))) (define-syntax 1- (syntax-rules () ((_ x) (- x 1)))) (define MOD 1000000007) (use data.heap) (define (solve) (read-number (n)) (read-numbers as) (read-number (q)) (read-numbers xs) (define sum (fold + 0 as)) (define heap (build-binary-heap (list->vector as))) (for-each print (map (lambda (x) (set! sum (let loop ((n (binary-heap-find-max heap)) (sum sum)) (if (<= x n) (let1 rem (modulo n x) (binary-heap-swap-max! heap rem) (loop (binary-heap-find-max heap) (- (+ sum rem) n))) sum))) sum) xs))) (solve)