結果
| 問題 |
No.2784 繰り上がりなし十進和
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2024-06-14 21:45:36 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 53 ms / 2,000 ms |
| コード長 | 917 bytes |
| コンパイル時間 | 26,712 ms |
| コンパイル使用メモリ | 384,140 KB |
| 実行使用メモリ | 9,216 KB |
| 最終ジャッジ日時 | 2024-06-14 21:46:08 |
| 合計ジャッジ時間 | 28,773 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 36 |
コンパイルメッセージ
warning: variable `A` should have a snake case name --> src/main.rs:20:19 | 20 | proconio::input!(A: [u32; 6]); | ^ help: convert the identifier to snake case: `a` | = note: `#[warn(non_snake_case)]` on by default
ソースコード
const TABLE: [[u32; 1000]; 1000] = {
let mut table = [[0u32; 1000]; 1000];
let mut x = 0;
while x < 1000 {
let mut y = 0;
while y < 1000 {
table[x as usize][y as usize] = (x % 10 + y % 10) % 10 + (x / 10 % 10 + y / 10 % 10) % 10 * 10 + (x / 100 + y / 100) % 10 * 100;
y += 1;
}
x += 1;
}
table
};
fn add(x: u32, y: u32) -> u32 {
TABLE[x as usize % 1000][y as usize % 1000] + TABLE[x as usize / 1000][y as usize / 1000] * 1000
}
fn main() {
proconio::input!(A: [u32; 6]);
let mut visited = vec![false; 1000000];
let mut stack = vec![];
for &a in &A {
if !visited[a as usize] {
visited[a as usize] = true;
stack.push(a);
}
}
while let Some(u) = stack.pop() {
for &a in &A {
let v = add(u, a);
if !visited[v as usize] {
visited[v as usize] = true;
stack.push(v);
}
}
}
let count = (0 .. 1000000).filter(|&i| visited[i] ).count();
println!("{count}");
}