| Task: | Hypyt |
| Sender: | Jaksu |
| Submission time: | 2025-11-08 13:43:20 +0200 |
| Language: | Rust (2021) |
| Status: | READY |
| Result: | 0 |
| group | verdict | score |
|---|---|---|
| #1 | WRONG ANSWER | 0 |
| #2 | WRONG ANSWER | 0 |
| #3 | WRONG ANSWER | 0 |
| #4 | WRONG ANSWER | 0 |
| #5 | WRONG ANSWER | 0 |
| test | verdict | time | group | |
|---|---|---|---|---|
| #1 | WRONG ANSWER | 0.00 s | 1, 2, 3, 4, 5 | details |
| #2 | WRONG ANSWER | 0.01 s | 1, 2, 3, 4, 5 | details |
| #3 | WRONG ANSWER | 0.00 s | 1, 2, 3, 4, 5 | details |
| #4 | WRONG ANSWER | 0.00 s | 1, 2, 3, 4, 5 | details |
| #5 | WRONG ANSWER | 0.00 s | 1, 2, 3, 4, 5 | details |
| #6 | TIME LIMIT EXCEEDED | -- | 2, 5 | details |
| #7 | WRONG ANSWER | 0.86 s | 2, 5 | details |
| #8 | WRONG ANSWER | 0.57 s | 2, 5 | details |
| #9 | TIME LIMIT EXCEEDED | -- | 3, 4, 5 | details |
| #10 | TIME LIMIT EXCEEDED | -- | 3, 4, 5 | details |
| #11 | TIME LIMIT EXCEEDED | -- | 3, 4, 5 | details |
| #12 | TIME LIMIT EXCEEDED | -- | 4, 5 | details |
| #13 | TIME LIMIT EXCEEDED | -- | 4, 5 | details |
| #14 | TIME LIMIT EXCEEDED | -- | 4, 5 | details |
| #15 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #16 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #17 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #18 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #19 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #20 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #21 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #22 | ACCEPTED | 0.00 s | 1, 2, 3, 4, 5 | details |
| #23 | ACCEPTED | 0.00 s | 1, 2, 3, 4, 5 | details |
| #24 | ACCEPTED | 0.41 s | 5 | details |
| #25 | ACCEPTED | 0.32 s | 5 | details |
| #26 | TIME LIMIT EXCEEDED | -- | 5 | details |
| #27 | ACCEPTED | 0.32 s | 5 | details |
Compiler report
warning: unused imports: `SystemTime`, `UNIX_EPOCH`
--> input/code.rs:4:17
|
4 | use std::time::{SystemTime, UNIX_EPOCH};
| ^^^^^^^^^^ ^^^^^^^^^^
|
= note: `#[warn(unused_imports)]` on by default
warning: type alias `NodeID` is never used
--> input/code.rs:6:6
|
6 | type NodeID = (usize, usize);
| ^^^^^^
|
= note: `#[warn(dead_code)]` on by default
warning: 2 warnings emittedCode
use std::io;
use std::collections::{HashMap, HashSet, VecDeque};
//use rand::{random, random_bool, random_range};
use std::time::{SystemTime, UNIX_EPOCH};
type NodeID = (usize, usize);
fn main() {
let mut input = String::new();
io::stdin().read_line(&mut input).expect("Failed to read input");
let startdata: Vec<usize> = input.split_whitespace().map(|e| e.parse::<usize>().unwrap()).collect();
let mut rowgrid: Vec<Vec<usize>> = vec!();
let mut colgrid: Vec<Vec<usize>> = vec!();
let mut boolgrid: Vec<Vec<bool>> = vec!();
for row in 0..startdata[0] {
rowgrid.push(Vec::new());
boolgrid.push(Vec::new());
let mut rowinput = String::new();
io::stdin().read_line(&mut rowinput).expect("Failed to read input");
let bytes = rowinput.into_bytes();
for c in 0..startdata[1] {
if row == 0 {
colgrid.push(Vec::new());
}
if bytes[c] == 46 {
rowgrid[row].push(c);
boolgrid[row].push(true);
colgrid[c].push(row);
} else {
boolgrid[row].push(false);
}
}
}
dbg!(&colgrid);
dbg!(&rowgrid);
let mut rowtorow: HashMap<usize, HashSet<usize>> = HashMap::new();
for row in 0..rowgrid.len() {
rowtorow.insert(row, HashSet::new());
for node in rowgrid[row].iter() {
for rowneighbor in colgrid[*node].iter() {
if *rowneighbor != row {
rowtorow.entry(row).and_modify(|v| {v.insert(*rowneighbor);});
}
}
}
}
dbg!(&rowtorow);
'question: for _q in 0..startdata[2] {
let mut questioninput = String::new();
io::stdin().read_line(&mut questioninput).expect("Failed to read input");
let questiondata: Vec<usize> = questioninput.split_whitespace().map(|e| e.parse::<usize>().unwrap()-1).collect();
let source = (questiondata[0], questiondata[1]);
let dest = (questiondata[2], questiondata[3]);
if source == dest {
println!("0");
continue 'question;
}
if source.0 == dest.0 || source.1 == dest.1 {
println!("1");
continue 'question;
}
let mut distancehash: HashMap<usize, usize> = HashMap::new();
distancehash.insert(source.0, 0);
let mut queue: VecDeque<usize> = VecDeque::new();
queue.push_front(source.0);
for neighborrow in colgrid[source.1].iter() {
if *neighborrow != source.0 {
distancehash.insert(*neighborrow, 1);
queue.push_front(*neighborrow);
}
}
while queue.len() != 0 {
let row = queue.pop_back().unwrap();
let dist = *distancehash.get(&row).unwrap();
let neighborrows = &rowtorow[&row];
dbg!(&dist);
dbg!(&row);
for neighborrow in neighborrows {
match distancehash.get(&neighborrow) {
Some(_) => {}
None => {
distancehash.insert(*neighborrow, dist+2);
queue.push_front(*neighborrow);
}
}
if *neighborrow == dest.0 {
println!("Checking!");
if colgrid[dest.1].contains(&row) {
println!("{}", dist+2);
println!("Contains");
continue 'question;
} else {
println!("{}", dist+3);
println!("Doesn't contain");
continue 'question;
}
}
}
}
println!("-1");
};
}Test details
Test 1 (public)
Group: 1, 2, 3, 4, 5
Verdict: WRONG ANSWER
| input |
|---|
| 4 6 5 .*.*** *...** *****. *..*.* ... |
| correct output |
|---|
| 1 0 3 3 -1 |
| user output |
|---|
| 1 0 Checking! 3 Doesn't contain ... |
Feedback: Output is longer than expected
Error:
[input/code.rs:39] &colgrid = [
[
0,
],
[
1,
3,
],
[
0,
1,
3,
],
[
1,
],
[
3,
],
[
2,
],
]
[input/code.rs:40] &rowgrid = [
[
0,
2,
],
[
1,
2,
3,
],
[
5,
],
[
1,
2,
4,
],
]
[input/code.rs:56] &rowtorow = {
2: {},
3: {
0,
1,
},
0: {
3,
1,
},
1: {
3,
0,
},
}
[input/code.rs:93] &dist = 0
[input/code.rs:94] &row = 0
[input/code.rs:93] &dist = 0
[input/code.rs:94] &row = 3
[input/code.rs:93] &dist = 0
[input/code.rs:94] &row = 2Test 2
Group: 1, 2, 3, 4, 5
Verdict: WRONG ANSWER
| input |
|---|
| 10 10 10 .......... .....*.... ........*. *.*....*.. ... |
| correct output |
|---|
| 1 2 1 2 2 ... |
| user output |
|---|
| 1 Checking! 2 Contains 1 ... |
Feedback: Output is longer than expected
Error:
[input/code.rs:39] &colgrid = [
[
0,
1,
2,
4,
5,
6,
7,
8,
9,
],
[
0,
1,
2,
3,
4,
5,
8,
],
[
0,
1,
2,
4,
6,
7,
8,
],
[
0,
1,
2,
3,
4,
5,
6,
8,
9,
],
[
0,
1,
2,
3,
4,
5,
6,
7,
8,
],
[
0,
2,
3,
4,
5,
7,
9,
],
[
0,
1,
2,
3,
4,
5,
6,
7,
9,
],
[
0,
1,
2,
4,
7,
8,
9,
],
[
0,
1,
3,
5,
7,
8,
9,
],
[
0,
1,
2,
3,
4,
5...Test 3
Group: 1, 2, 3, 4, 5
Verdict: WRONG ANSWER
| input |
|---|
| 10 10 10 *...***.** *****.*... **..**.**. ..**.**.*. ... |
| correct output |
|---|
| 1 2 2 1 2 ... |
| user output |
|---|
| 1 Checking! 2 Contains Checking! ... |
Feedback: Output is longer than expected
Error:
[input/code.rs:39] &colgrid = [
[
3,
4,
5,
8,
],
[
0,
3,
4,
5,
6,
8,
],
[
0,
2,
4,
7,
8,
9,
],
[
0,
2,
4,
5,
6,
7,
],
[
3,
6,
7,
],
[
1,
9,
],
[
2,
4,
6,
8,
],
[
0,
1,
3,
4,
],
[
1,
4,
5,
6,
7,
],
[
1,
2,
3,
4,
5,
7,
9,
],
]
[input/code.rs:40] &rowgrid = [
[
1,
2,
3,
7,
],
[
5,
7,
8,
9,
],
[
2,
3,
6,
9,
],
[
0,
1,
4,
7,
9,
],
[
0,
1,
2,
3...Test 4
Group: 1, 2, 3, 4, 5
Verdict: WRONG ANSWER
| input |
|---|
| 10 10 10 ***.*.**** ********** *.******** .*.***.**. ... |
| correct output |
|---|
| 3 4 2 3 4 ... |
| user output |
|---|
| Checking! 3 Doesn't contain Checking! 4 ... |
Feedback: Output is longer than expected
Error:
[input/code.rs:39] &colgrid = [
[
3,
8,
],
[
2,
9,
],
[
3,
7,
],
[
0,
7,
],
[
8,
9,
],
[
0,
5,
8,
],
[
3,
],
[
6,
],
[
9,
],
[
3,
7,
9,
],
]
[input/code.rs:40] &rowgrid = [
[
3,
5,
],
[],
[
1,
],
[
0,
2,
6,
9,
],
[],
[
5,
],
[
7,
],
[
2,
3,
9,
],
[
0,
4,
5,
],
[
1,
4,
8,
9,
],
]
[input/code.rs:56] &rowtorow = {
1: {},
2: {
9,
},
0: {
8,
5,
7,
},
7: {
9,
0,
3,
},
6: {},
5: {
0,
8,
},
4: {},
3: {
7,
8,...Test 5
Group: 1, 2, 3, 4, 5
Verdict: WRONG ANSWER
| input |
|---|
| 10 10 1 .****.**** **.**..*** ********** *******..* ... |
| correct output |
|---|
| 7 |
| user output |
|---|
| Checking! 7 Doesn't contain |
Feedback: Output is longer than expected
Error:
[input/code.rs:39] &colgrid = [
[
0,
5,
],
[],
[
1,
],
[
9,
],
[
6,
],
[
0,
1,
8,
],
[
1,
9,
],
[
3,
5,
6,
],
[
3,
],
[],
]
[input/code.rs:40] &rowgrid = [
[
0,
5,
],
[
2,
5,
6,
],
[],
[
7,
8,
],
[],
[
0,
7,
],
[
4,
7,
],
[],
[
5,
],
[
3,
6,
],
]
[input/code.rs:56] &rowtorow = {
5: {
0,
3,
6,
},
4: {},
3: {
5,
6,
},
1: {
8,
0,
9,
},
8: {
1,
0,
},
9: {
1,
},
0: {
1,
8,
5,
},
6: {
5,
3,
},
7: {},
2: {},
}
[input/code.rs:93] &dist = 0
[inp...Test 6
Group: 2, 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 250 .*...*.....*******..**...*....... |
| correct output |
|---|
| 2 3 3 2 2 ... |
| user output |
|---|
| (empty) |
Test 7
Group: 2, 5
Verdict: WRONG ANSWER
| input |
|---|
| 250 250 250 ...*......**.**.*.*..**..*..**... |
| correct output |
|---|
| 2 2 2 2 3 ... |
| user output |
|---|
| Checking! 2 Contains Checking! 2 ... |
Feedback: Output is longer than expected
Error:
[input/code.rs:39] &colgrid = [
[
0,
2,
3,
4,
8,
9,
11,
12,
15,
16,
20,
21,
22,
23,
26,
28,
29,
32,
36,
37,
41,
45,
46,
47,
50,
52,
53,
54,
62,
64,
67,
68,
70,
72,
74,
75,
77,
78,
79,
80,
84,
88,
93,
96,
97,
98,
99,
102,
105,
106,
107,
108,
109,
110,
111,
112,
114,
116,
120,
123,
127,
128,
130,
131,
133,
136,
138,
139,
141,
144,
145,
149,
152,
153,
154,
155,
161,
163,...Test 8
Group: 2, 5
Verdict: WRONG ANSWER
| input |
|---|
| 250 250 250 **..**..****.****.*.***.***..*... |
| correct output |
|---|
| 2 3 3 3 3 ... |
| user output |
|---|
| Checking! 3 Doesn't contain Checking! 3 ... |
Feedback: Output is longer than expected
Error:
[input/code.rs:39] &colgrid = [
[
3,
4,
12,
16,
21,
26,
29,
30,
31,
33,
38,
44,
46,
47,
55,
56,
59,
65,
67,
69,
76,
82,
83,
91,
93,
95,
100,
103,
113,
115,
137,
138,
150,
154,
173,
175,
180,
182,
190,
193,
194,
195,
202,
205,
207,
211,
214,
220,
222,
224,
225,
227,
228,
232,
237,
239,
],
[
2,
8,
10,
12,
13,
16,
21,
26,
29,
35,
36,
39,
42,
43,
51,
52,
54,
65,
68,
72,
73,...Test 9
Group: 3, 4, 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 40 40 200000 ...*.**.*..*.............*.*..... |
| correct output |
|---|
| 2 2 2 2 2 ... |
| user output |
|---|
| (empty) |
Test 10
Group: 3, 4, 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 40 40 200000 **.**..*.*.*.******....****.*.... |
| correct output |
|---|
| 2 1 3 2 2 ... |
| user output |
|---|
| (empty) |
Test 11
Group: 3, 4, 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 40 40 200000 .*.*.**.*****.***.*.****.**.**... |
| correct output |
|---|
| 3 3 3 3 3 ... |
| user output |
|---|
| (empty) |
Test 12
Group: 4, 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 80 80 200000 *....**.***..****...*.....*...... |
| correct output |
|---|
| 2 2 2 2 2 ... |
| user output |
|---|
| (empty) |
Test 13
Group: 4, 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 80 80 200000 .***.*..*.***..*****....**...*... |
| correct output |
|---|
| 3 2 2 3 2 ... |
| user output |
|---|
| (empty) |
Test 14
Group: 4, 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 80 80 200000 *******.*****.*..*..****...***... |
| correct output |
|---|
| 2 3 1 2 2 ... |
| user output |
|---|
| (empty) |
Test 15
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 *....*..*..*..**..*.........**... |
| correct output |
|---|
| 3 2 2 2 2 ... |
| user output |
|---|
| (empty) |
Test 16
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 ..*....*..*......*.**.*.*..***... |
| correct output |
|---|
| 2 2 2 2 2 ... |
| user output |
|---|
| (empty) |
Test 17
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 *..*.*****.*********.****.****... |
| correct output |
|---|
| 3 3 2 2 2 ... |
| user output |
|---|
| (empty) |
Test 18
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 *********.**********.******.**... |
| correct output |
|---|
| 3 3 3 3 3 ... |
| user output |
|---|
| (empty) |
Test 19
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 .*****************************... |
| correct output |
|---|
| 104 422 145 93 65 ... |
| user output |
|---|
| (empty) |
Test 20
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 ..****************************... |
| correct output |
|---|
| 57 155 38 65 98 ... |
| user output |
|---|
| (empty) |
Test 21
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 .*****************************... |
| correct output |
|---|
| 498 498 498 498 498 ... |
| user output |
|---|
| (empty) |
Test 22
Group: 1, 2, 3, 4, 5
Verdict: ACCEPTED
| input |
|---|
| 10 1 10 * * . * ... |
| correct output |
|---|
| 0 1 1 0 0 ... |
| user output |
|---|
| 0 1 1 0 0 ... |
Error:
[input/code.rs:39] &colgrid = [
[
2,
5,
9,
],
]
[input/code.rs:40] &rowgrid = [
[],
[],
[
0,
],
[],
[],
[
0,
],
[],
[],
[],
[
0,
],
]
[input/code.rs:56] &rowtorow = {
3: {},
7: {},
9: {
5,
2,
},
6: {},
0: {},
4: {},
2: {
5,
9,
},
1: {},
8: {},
5: {
9,
2,
},
}Test 23
Group: 1, 2, 3, 4, 5
Verdict: ACCEPTED
| input |
|---|
| 1 10 10 ........*. 1 7 1 10 1 4 1 7 1 5 1 1 ... |
| correct output |
|---|
| 1 1 1 1 1 ... |
| user output |
|---|
| 1 1 1 1 1 ... |
Error:
[input/code.rs:39] &colgrid = [
[
0,
],
[
0,
],
[
0,
],
[
0,
],
[
0,
],
[
0,
],
[
0,
],
[
0,
],
[],
[
0,
],
]
[input/code.rs:40] &rowgrid = [
[
0,
1,
2,
3,
4,
5,
6,
7,
9,
],
]
[input/code.rs:56] &rowtorow = {
0: {},
}Test 24
Group: 5
Verdict: ACCEPTED
| input |
|---|
| 250 1 200000 * . * . ... |
| correct output |
|---|
| 1 1 1 1 1 ... |
| user output |
|---|
| 1 1 1 1 1 ... |
Error:
[input/code.rs:39] &colgrid = [
[
1,
3,
4,
7,
9,
13,
14,
17,
18,
22,
25,
30,
31,
32,
34,
35,
36,
41,
42,
43,
45,
46,
47,
48,
50,
52,
57,
61,
64,
67,
68,
69,
70,
71,
72,
75,
76,
77,
78,
81,
83,
84,
85,
86,
87,
88,
91,
92,
93,
94,
96,
97,
98,
100,
103,
106,
107,
109,
113,
114,
115,
116,
119,
120,
122,
124,
125,
127,
128,
129,
132,
136,
138,
139,
141,
144,
145,
149,...Test 25
Group: 5
Verdict: ACCEPTED
| input |
|---|
| 1 250 200000 *.*.*...*.*.**.***..**.*.*..**... |
| correct output |
|---|
| 1 1 1 1 1 ... |
| user output |
|---|
| 1 1 1 1 1 ... |
Error:
[input/code.rs:39] &colgrid = [
[],
[
0,
],
[],
[
0,
],
[],
[
0,
],
[
0,
],
[
0,
],
[],
[
0,
],
[],
[
0,
],
[],
[],
[
0,
],
[],
[],
[],
[
0,
],
[
0,
],
[],
[],
[
0,
],
[],
[
0,
],
[],
[
0,
],
[
0,
],
[],
[],
[],
[],
[
0,
],
[],
[
0,
],
[],
[
0,
],
[],
[],
[
0,
],
[
0,
],
[
0,
],
[
0,
],
[
0,
],
[],
[],
[
0,
],
[],
[],
[
0,
],
[
0,
],
[],
[
0,
],
[
0,
],
[],
[
0,
],
[
0,
],
[
0,
],
[
0,
],...Test 26
Group: 5
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 250 250 200000 ................................. |
| correct output |
|---|
| 2 2 2 2 2 ... |
| user output |
|---|
| (empty) |
Test 27
Group: 5
Verdict: ACCEPTED
| input |
|---|
| 250 250 200000 ******************************... |
| correct output |
|---|
| 0 0 0 0 0 ... |
| user output |
|---|
| 0 0 0 0 0 ... |
Error:
[input/code.rs:39] &colgrid = [
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],
[],...