| Task: | Shortest palindrome |
| Sender: | aalto25h_005 |
| Submission time: | 2025-10-22 17:10:35 +0300 |
| Language: | Rust (2021) |
| Status: | READY |
| Result: | ACCEPTED |
| test | verdict | time | |
|---|---|---|---|
| #1 | ACCEPTED | 0.00 s | details |
| #2 | ACCEPTED | 0.00 s | details |
| #3 | ACCEPTED | 0.00 s | details |
| #4 | ACCEPTED | 0.00 s | details |
| #5 | ACCEPTED | 0.00 s | details |
| #6 | ACCEPTED | 0.00 s | details |
| #7 | ACCEPTED | 0.00 s | details |
| #8 | ACCEPTED | 0.00 s | details |
| #9 | ACCEPTED | 0.00 s | details |
| #10 | ACCEPTED | 0.00 s | details |
| #11 | ACCEPTED | 0.00 s | details |
| #12 | ACCEPTED | 0.00 s | details |
| #13 | ACCEPTED | 0.00 s | details |
| #14 | ACCEPTED | 0.00 s | details |
| #15 | ACCEPTED | 0.00 s | details |
| #16 | ACCEPTED | 0.00 s | details |
| #17 | ACCEPTED | 0.00 s | details |
| #18 | ACCEPTED | 0.00 s | details |
| #19 | ACCEPTED | 0.00 s | details |
| #20 | ACCEPTED | 0.00 s | details |
| #21 | ACCEPTED | 0.00 s | details |
| #22 | ACCEPTED | 0.00 s | details |
| #23 | ACCEPTED | 0.00 s | details |
| #24 | ACCEPTED | 0.00 s | details |
| #25 | ACCEPTED | 0.00 s | details |
| #26 | ACCEPTED | 0.00 s | details |
| #27 | ACCEPTED | 0.00 s | details |
| #28 | ACCEPTED | 0.00 s | details |
| #29 | ACCEPTED | 0.00 s | details |
| #30 | ACCEPTED | 0.00 s | details |
| #31 | ACCEPTED | 0.00 s | details |
| #32 | ACCEPTED | 0.00 s | details |
| #33 | ACCEPTED | 0.00 s | details |
| #34 | ACCEPTED | 0.00 s | details |
| #35 | ACCEPTED | 0.00 s | details |
| #36 | ACCEPTED | 0.00 s | details |
| #37 | ACCEPTED | 0.00 s | details |
| #38 | ACCEPTED | 0.00 s | details |
| #39 | ACCEPTED | 0.00 s | details |
| #40 | ACCEPTED | 0.00 s | details |
| #41 | ACCEPTED | 0.00 s | details |
| #42 | ACCEPTED | 0.00 s | details |
| #43 | ACCEPTED | 0.00 s | details |
| #44 | ACCEPTED | 0.00 s | details |
| #45 | ACCEPTED | 0.00 s | details |
| #46 | ACCEPTED | 0.00 s | details |
| #47 | ACCEPTED | 0.00 s | details |
| #48 | ACCEPTED | 0.00 s | details |
| #49 | ACCEPTED | 0.00 s | details |
| #50 | ACCEPTED | 0.00 s | details |
| #51 | ACCEPTED | 0.00 s | details |
| #52 | ACCEPTED | 0.00 s | details |
| #53 | ACCEPTED | 0.00 s | details |
| #54 | ACCEPTED | 0.00 s | details |
| #55 | ACCEPTED | 0.00 s | details |
| #56 | ACCEPTED | 0.00 s | details |
| #57 | ACCEPTED | 0.00 s | details |
| #58 | ACCEPTED | 0.00 s | details |
| #59 | ACCEPTED | 0.00 s | details |
| #60 | ACCEPTED | 0.00 s | details |
| #61 | ACCEPTED | 0.00 s | details |
| #62 | ACCEPTED | 0.00 s | details |
| #63 | ACCEPTED | 0.01 s | details |
| #64 | ACCEPTED | 0.00 s | details |
| #65 | ACCEPTED | 0.01 s | details |
| #66 | ACCEPTED | 0.00 s | details |
| #67 | ACCEPTED | 0.01 s | details |
| #68 | ACCEPTED | 0.00 s | details |
Compiler report
warning: unused imports: `Reverse`, `max`, `min`
--> input/code.rs:1:16
|
1 | use std::cmp::{max, min, Reverse};
| ^^^ ^^^ ^^^^^^^
|
= note: `#[warn(unused_imports)]` on by default
warning: unused imports: `BTreeMap`, `BinaryHeap`, `HashMap`, `HashSet`
--> input/code.rs:2:24
|
2 | use std::collections::{BTreeMap, BinaryHeap, HashMap, HashSet};
| ^^^^^^^^ ^^^^^^^^^^ ^^^^^^^ ^^^^^^^
warning: unused import: `std::process::exit`
--> input/code.rs:4:5
|
4 | use std::process::exit;
| ^^^^^^^^^^^^^^^^^^
warning: value assigned to `found` is never read
--> input/code.rs:49:13
|
49 | let mut found = false;
| ^^^^^
|
= help: maybe it is overwritten before being read?
= note: `#[warn(unused_assignments)]` on by default
warning: 4 warnings emittedCode
use std::cmp::{max, min, Reverse};
use std::collections::{BTreeMap, BinaryHeap, HashMap, HashSet};
use std::io::{self, Read};
use std::process::exit;
macro_rules! input {
($it: expr) => {
$it.next().unwrap().parse().unwrap()
};
($it: expr, $T: ty) => {
$it.next().unwrap().parse::<$T>().unwrap()
};
}
/*
mod classes;
mod homework;
fn main() {
// println!("{}", "-".repeat(20));
classes::c15::task1();
// homework::hw5::task2();
// println!("{}", "-".repeat(20));
}
// */
#[inline]
fn is_palindrome(v: &Vec<char>, mut i: usize, mut j: usize) -> bool {
let mut pallindrome = true;
while i<=j && pallindrome {
pallindrome = v[i] == v[j];
i+=1;
j-=1;
}
pallindrome
}
fn main() {
let mut buf = String::new();
io::stdin().read_to_string(&mut buf).unwrap();
let mut it = buf.split_whitespace();
let s: String = input!(it);
let v: Vec<char> = s.chars().collect();
let n = v.len();
let mut found = false;
for i in 1..3 {
for j in 0..(n-i) {
// println!("{}-{}", j, j+i);
found = is_palindrome(&v, j, j+i);
if found {
println!("{}", i+1);
return;
}
}
}
println!("-1");
}Test details
Test 1
Verdict: ACCEPTED
| input |
|---|
| sl |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 2
Verdict: ACCEPTED
| input |
|---|
| uz |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 3
Verdict: ACCEPTED
| input |
|---|
| vum |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 4
Verdict: ACCEPTED
| input |
|---|
| ltw |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 5
Verdict: ACCEPTED
| input |
|---|
| srhm |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 6
Verdict: ACCEPTED
| input |
|---|
| agwj |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 7
Verdict: ACCEPTED
| input |
|---|
| vcgm |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 8
Verdict: ACCEPTED
| input |
|---|
| cwld |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 9
Verdict: ACCEPTED
| input |
|---|
| psvpw |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 10
Verdict: ACCEPTED
| input |
|---|
| zsyad |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 11
Verdict: ACCEPTED
| input |
|---|
| eayoy |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 12
Verdict: ACCEPTED
| input |
|---|
| bsvhd |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 13
Verdict: ACCEPTED
| input |
|---|
| xezws |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 14
Verdict: ACCEPTED
| input |
|---|
| bwvfj |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 15
Verdict: ACCEPTED
| input |
|---|
| yfvbj |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 16
Verdict: ACCEPTED
| input |
|---|
| fuilz |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 17
Verdict: ACCEPTED
| input |
|---|
| agwjn |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 18
Verdict: ACCEPTED
| input |
|---|
| jnmma |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 19
Verdict: ACCEPTED
| input |
|---|
| psvpwowlqj |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 20
Verdict: ACCEPTED
| input |
|---|
| zsyadhzdgc |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 21
Verdict: ACCEPTED
| input |
|---|
| eayoylmkie |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 22
Verdict: ACCEPTED
| input |
|---|
| bsvhdnoxlx |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 23
Verdict: ACCEPTED
| input |
|---|
| xezwspfdzf |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 24
Verdict: ACCEPTED
| input |
|---|
| bwvfjxzmcp |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 25
Verdict: ACCEPTED
| input |
|---|
| yfvbjczpcn |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 26
Verdict: ACCEPTED
| input |
|---|
| fuilzslzio |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 27
Verdict: ACCEPTED
| input |
|---|
| agwjnvgkap |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 28
Verdict: ACCEPTED
| input |
|---|
| jnmmadidaf |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 29
Verdict: ACCEPTED
| input |
|---|
| psvpwowlqjlhxbzhjmuvnmokyvbicq... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 30
Verdict: ACCEPTED
| input |
|---|
| zsyadhzdgckekirkyowkirnflwfanr... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 31
Verdict: ACCEPTED
| input |
|---|
| eayoylmkiefsqdhmgqvnrdmnpesugw... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 32
Verdict: ACCEPTED
| input |
|---|
| bsvhdnoxlxadbfgbclsadlqfhjrmpx... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 33
Verdict: ACCEPTED
| input |
|---|
| xezwspfdzfasgxlquafowjzpekpvap... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 34
Verdict: ACCEPTED
| input |
|---|
| bwvfjxzmcpktjnmhzevcqtvlgetwch... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 35
Verdict: ACCEPTED
| input |
|---|
| yfvbjczpcnpknimqvltkngpeqszxvm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 36
Verdict: ACCEPTED
| input |
|---|
| fuilzslziogncbkgamnrwuijkbrhrx... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 37
Verdict: ACCEPTED
| input |
|---|
| agwjnvgkapltknwmyodstksvqaljhm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 38
Verdict: ACCEPTED
| input |
|---|
| jnmmadidafwkdgdckimeiwjytbzsso... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 39
Verdict: ACCEPTED
| input |
|---|
| psvpwowlqjlhxbzhjmuvnmokyvbicq... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 40
Verdict: ACCEPTED
| input |
|---|
| zsyadhzdgckekirkyowkirnflwfanr... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 41
Verdict: ACCEPTED
| input |
|---|
| eayoylmkiefsqdhmgqvnrdmnpesugw... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 42
Verdict: ACCEPTED
| input |
|---|
| bsvhdnoxlxadbfgbclsadlqfhjrmpx... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 43
Verdict: ACCEPTED
| input |
|---|
| xezwspfdzfasgxlquafowjzpekpvap... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 44
Verdict: ACCEPTED
| input |
|---|
| bwvfjxzmcpktjnmhzevcqtvlgetwch... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 45
Verdict: ACCEPTED
| input |
|---|
| yfvbjczpcnpknimqvltkngpeqszxvm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 46
Verdict: ACCEPTED
| input |
|---|
| fuilzslziogncbkgamnrwuijkbrhrx... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 47
Verdict: ACCEPTED
| input |
|---|
| agwjnvgkapltknwmyodstksvqaljhm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 48
Verdict: ACCEPTED
| input |
|---|
| jnmmadidafwkdgdckimeiwjytbzsso... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 49
Verdict: ACCEPTED
| input |
|---|
| psvpwowlqjlhxbzhjmuvnmokyvbicq... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 50
Verdict: ACCEPTED
| input |
|---|
| zsyadhzdgckekirkyowkirnflwfanr... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 51
Verdict: ACCEPTED
| input |
|---|
| eayoylmkiefsqdhmgqvnrdmnpesugw... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 52
Verdict: ACCEPTED
| input |
|---|
| bsvhdnoxlxadbfgbclsadlqfhjrmpx... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 53
Verdict: ACCEPTED
| input |
|---|
| xezwspfdzfasgxlquafowjzpekpvap... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 54
Verdict: ACCEPTED
| input |
|---|
| bwvfjxzmcpktjnmhzevcqtvlgetwch... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 55
Verdict: ACCEPTED
| input |
|---|
| yfvbjczpcnpknimqvltkngpeqszxvm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 56
Verdict: ACCEPTED
| input |
|---|
| fuilzslziogncbkgamnrwuijkbrhrx... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 57
Verdict: ACCEPTED
| input |
|---|
| agwjnvgkapltknwmyodstksvqaljhm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 58
Verdict: ACCEPTED
| input |
|---|
| jnmmadidafwkdgdckimeiwjytbzsso... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 59
Verdict: ACCEPTED
| input |
|---|
| psvpwowlqjlhxbzhjmuvnmokyvbicq... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 60
Verdict: ACCEPTED
| input |
|---|
| zsyadhzdgckekirkyowkirnflwfanr... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 61
Verdict: ACCEPTED
| input |
|---|
| eayoylmkiefsqdhmgqvnrdmnpesugw... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 62
Verdict: ACCEPTED
| input |
|---|
| bsvhdnoxlxadbfgbclsadlqfhjrmpx... |
| correct output |
|---|
| 3 |
| user output |
|---|
| 3 |
Test 63
Verdict: ACCEPTED
| input |
|---|
| xezwspfdzfasgxlquafowjzpekpvap... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 64
Verdict: ACCEPTED
| input |
|---|
| bwvfjxzmcpktjnmhzevcqtvlgetwch... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 65
Verdict: ACCEPTED
| input |
|---|
| yfvbjczpcnpknimqvltkngpeqszxvm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 66
Verdict: ACCEPTED
| input |
|---|
| fuilzslziogncbkgamnrwuijkbrhrx... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
Test 67
Verdict: ACCEPTED
| input |
|---|
| agwjnvgkapltknwmyodstksvqaljhm... |
| correct output |
|---|
| -1 |
| user output |
|---|
| -1 |
Test 68
Verdict: ACCEPTED
| input |
|---|
| jnmmadidafwkdgdckimeiwjytbzsso... |
| correct output |
|---|
| 2 |
| user output |
|---|
| 2 |
