結果

問題 No.327 アルファベット列
ユーザー Leonardone
提出日時 2015-12-20 03:16:19
言語 Rust
(1.83.0 + proconio)
結果
AC  
実行時間 1 ms / 2,000 ms
コード長 692 bytes
コンパイル時間 12,820 ms
コンパイル使用メモリ 380,040 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-06 21:20:55
合計ジャッジ時間 14,148 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 50
権限があれば一括ダウンロードができます

ソースコード

diff #

// yukicoder My Practice
// author: Leonardone @ NEETSDKASU
use std::io;

fn read_int64() -> i64 {
    let mut val_str = String::new();
    io::stdin().read_line(&mut val_str).ok().expect("");
    return val_str.trim().parse().ok().expect("");
}

fn main() {
    let al : Vec<char> = String::from("ABCDEFGHIJKLMNOPQRSTUVWXYZ").chars().collect();
    let n = read_int64() + 1;
    let mut s : i64 = 1;
    let mut d1 : i64 = 1;
    let mut d2 : i64 = 26;
    let mut ans = String::new();
    loop {
        let idx = (((n - s) % d2) / d1) as usize;
        ans.insert(0, al[idx]);
        d1 = d2;
        d2 *= 26;
        s += d1;
        if s > n { break; }
    }
    println!("{}", ans);
}
0