Task: | Monistus |
Sender: | EmuBird |
Submission time: | 2023-10-30 21:42:37 +0200 |
Language: | Rust |
Status: | READY |
Result: | 0 |
group | verdict | score |
---|---|---|
#1 | RUNTIME ERROR | 0 |
#2 | RUNTIME ERROR | 0 |
test | verdict | time | group | |
---|---|---|---|---|
#1 | RUNTIME ERROR | 0.00 s | 1, 2 | details |
#2 | RUNTIME ERROR | 0.00 s | 1, 2 | details |
#3 | RUNTIME ERROR | 0.00 s | 1, 2 | details |
#4 | RUNTIME ERROR | 0.00 s | 1, 2 | details |
#5 | RUNTIME ERROR | 0.00 s | 1, 2 | details |
#6 | RUNTIME ERROR | 0.00 s | 1, 2 | details |
#7 | RUNTIME ERROR | 0.00 s | 1, 2 | details |
#8 | RUNTIME ERROR | 0.00 s | 2 | details |
#9 | RUNTIME ERROR | 0.00 s | 2 | details |
#10 | RUNTIME ERROR | 0.00 s | 2 | details |
#11 | RUNTIME ERROR | 0.01 s | 2 | details |
#12 | RUNTIME ERROR | 0.01 s | 2 | details |
#13 | RUNTIME ERROR | 0.01 s | 2 | details |
#14 | RUNTIME ERROR | 0.01 s | 2 | details |
Compiler report
warning: variable does not need to be mutable --> input/code.rs:13:9 | 13 | let mut i: usize = 0; | ----^ | | | help: remove this `mut` | = note: `#[warn(unused_mut)]` on by default warning: variable does not need to be mutable --> input/code.rs:66:14 | 66 | fn duplicate(mut substring: VecDeque<char>, times: u32) -> VecDeque<char> { | ----^^^^^^^^^ | | | help: remove this `mut` warning: 2 warnings emitted
Code
use std::collections::VecDeque; fn main() { let mut input: String = String::new(); std::io::stdin().read_line(&mut input).unwrap(); input = input.strip_suffix("\n").unwrap().to_string(); println!("{}", process(input.chars().collect())) } fn process(mut input: VecDeque<char>) -> String { let mut output = String::new(); let mut i: usize = 0; while i < input.len() { let character = input.pop_front().unwrap(); match character.to_digit(10) { None => { output.push(character); } Some(len) => { let mut duplicate_times = 2; // Try optimizations { let mut n = i + 1; while n < input.len() { match input[n].to_digit(10) { Some(subsequent_number) => { // n and [n, inf[ subsequently cause an infinite loop. if subsequent_number >= len { panic!("Infinite loop! Check your input.") } // n and n-1 subsequently are equal to doubling twice. if subsequent_number as usize == len as usize - (n - i) { duplicate_times *= 2; input.pop_front(); continue; } } _ => { break; } } n += 1; } } let capture = input.drain(i .. i + len as usize).collect(); // Remove duplicated area let mut duplicate = duplicate(capture, duplicate_times); // Put back in duplicated form let duplicate_length = duplicate.len(); for _ in 0..duplicate_length { input.insert(i, duplicate.pop_back().unwrap()) } } } } return output; } fn duplicate(mut substring: VecDeque<char>, times: u32) -> VecDeque<char> { // Is this seriously the best way to do this in Rust? let mut out = VecDeque::new(); for _ in 0..times { out.append(&mut substring.clone()); } return out }
Test details
Test 1
Group: 1, 2
Verdict: RUNTIME ERROR
input |
---|
987654321o987654321p |
correct output |
---|
oooooooooooooooooooooooooooooo... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 2
Group: 1, 2
Verdict: RUNTIME ERROR
input |
---|
1e1o1zo1r1h1y1m1b1mn |
correct output |
---|
eeoozzorrhhyymmbbmmn |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 3
Group: 1, 2
Verdict: RUNTIME ERROR
input |
---|
h4y21n7dz6vr1p4go1ec |
correct output |
---|
hynnnnynnnndzvrppdzvrppdzvrppg... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 4
Group: 1, 2
Verdict: RUNTIME ERROR
input |
---|
bv2olah1h6o4f2mx3z1k |
correct output |
---|
bvololahhhofmxmxfmxmxofmxmxfmx... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 5
Group: 1, 2
Verdict: RUNTIME ERROR
input |
---|
xewpp2f1l6a5jp1v2v1y |
correct output |
---|
xewppfffllajpvvajpvvajpvvjpjpv... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 6
Group: 1, 2
Verdict: RUNTIME ERROR
input |
---|
1v4z1kjm1t6vp5c1m2np |
correct output |
---|
vvzkkjzkkjmttvpcmmvpcmmvpcmmnc... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 7
Group: 1, 2
Verdict: RUNTIME ERROR
input |
---|
y2bl9cp21v7kgesxm2uv |
correct output |
---|
yblblcpvvvvkgecpkkkkgecpvvvvkg... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 8
Group: 2
Verdict: RUNTIME ERROR
input |
---|
987654321b987654321f987654321u... |
correct output |
---|
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbb... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 9
Group: 2
Verdict: RUNTIME ERROR
input |
---|
agjv4321w9dskvax5ws21r321l9n7d... |
correct output |
---|
agjvwwwwwwwwwwwwwwwwdskvaxwsds... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 10
Group: 2
Verdict: RUNTIME ERROR
input |
---|
4mr1d71k432jt9sddyoy2oq7jvc1bm... |
correct output |
---|
mrddmrddkkjtjtjtjtjtjtjtjtkkjt... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 11
Group: 2
Verdict: RUNTIME ERROR
input |
---|
1a1l1m1a1t1gc1yv1x1p1w1x1d1d1p... |
correct output |
---|
aallmmaattggcyyvxxppwwxxddddpp... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 12
Group: 2
Verdict: RUNTIME ERROR
input |
---|
321e321b321a321r321m321f321s32... |
correct output |
---|
eeeeeeeebbbbbbbbaaaaaaaarrrrrr... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 13
Group: 2
Verdict: RUNTIME ERROR
input |
---|
4321e4321l4321t4321w4321g4321c... |
correct output |
---|
eeeeeeeeeeeeeeeellllllllllllll... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...
Test 14
Group: 2
Verdict: RUNTIME ERROR
input |
---|
987654321u987654321p987654321g... |
correct output |
---|
uuuuuuuuuuuuuuuuuuuuuuuuuuuuuu... |
user output |
---|
(empty) |
Error:
thread 'main' panicked at 'Infinite loop! Check your input.', input/code.rs:32:37 note: ru...