結果
問題 | No.1416 ショッピングモール |
ユーザー |
|
提出日時 | 2021-03-05 21:45:38 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 6 ms / 1,000 ms |
コード長 | 596 bytes |
コンパイル時間 | 11,913 ms |
コンパイル使用メモリ | 377,920 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-07 01:17:59 |
合計ジャッジ時間 | 12,866 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 |
ソースコード
use std::io::*; fn main() { let mut s: String = String::new(); std::io::stdin().read_to_string(&mut s).ok(); let mut itr = s.trim().split_whitespace(); let n: usize = itr.next().unwrap().parse().unwrap(); let mut a: Vec<i32> = (0..n) .map(|_| itr.next().unwrap().parse().unwrap()) .collect(); a.sort_by_key(|x| -x); let mut now = 0; let mut f = 0; let mut ans = 0; for &v in a.iter() { ans += f * v; now += 1; if (1 << f) == now { now = 0; f += 1; } } println!("{}", ans); }