結果

問題 No.3456 Common Difference is D
コンテスト
ユーザー NakLon131
提出日時 2026-02-28 14:37:09
言語 Rust
(1.93.0 + proconio + num + itertools)
コンパイル:
/usr/bin/rustc_custom
実行:
./target/release/main
結果
AC  
実行時間 23 ms / 2,000 ms
コード長 631 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,882 ms
コンパイル使用メモリ 206,756 KB
実行使用メモリ 7,844 KB
最終ジャッジ日時 2026-02-28 14:37:23
合計ジャッジ時間 3,641 ms
ジャッジサーバーID
(参考情報)
judge7 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 20
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

use std::collections::HashMap;

use proconio::input;

fn main() {
    input! {
        n: usize,
        d: i64,
        a: [i64; n],
    }

    let mut mp = HashMap::new();

    let mut ans = 0usize;

    for aa in a {
        // aaに対して、-Dの個数 * -2Dの個数
        let mut cnt1 = 0;
        if mp.contains_key(&(aa - d)) {
            cnt1 = *mp.get(&(aa - d)).unwrap();
        }
        let mut cnt2 = 0;
        if mp.contains_key(&(aa - 2*d)) {
            cnt2 = *mp.get(&(aa - 2*d)).unwrap();
        }

        ans += cnt1 * cnt2;

        *mp.entry(aa).or_insert(0) += 1;
    }

    println!("{}", ans);
}
0