Submission details
Task:Bracket sequence
Sender:aalto25j_003
Submission time:2025-11-05 17:22:58 +0200
Language:Rust (2021)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.00 sdetails
#7ACCEPTED0.00 sdetails
#8ACCEPTED0.00 sdetails
#9ACCEPTED0.00 sdetails
#10ACCEPTED0.00 sdetails
#11ACCEPTED0.00 sdetails
#12ACCEPTED0.00 sdetails
#13ACCEPTED0.00 sdetails
#14ACCEPTED0.00 sdetails
#15ACCEPTED0.00 sdetails
#16ACCEPTED0.00 sdetails
#17ACCEPTED0.00 sdetails
#18ACCEPTED0.00 sdetails
#19ACCEPTED0.00 sdetails
#20ACCEPTED0.00 sdetails
#21ACCEPTED0.00 sdetails
#22ACCEPTED0.00 sdetails
#23ACCEPTED0.00 sdetails
#24ACCEPTED0.00 sdetails
#25ACCEPTED0.00 sdetails
#26ACCEPTED0.00 sdetails
#27ACCEPTED0.00 sdetails
#28ACCEPTED0.00 sdetails
#29ACCEPTED0.00 sdetails
#30ACCEPTED0.00 sdetails
#31ACCEPTED0.00 sdetails
#32ACCEPTED0.00 sdetails
#33ACCEPTED0.00 sdetails
#34ACCEPTED0.00 sdetails
#35ACCEPTED0.00 sdetails
#36ACCEPTED0.00 sdetails
#37ACCEPTED0.00 sdetails
#38ACCEPTED0.00 sdetails
#39ACCEPTED0.00 sdetails
#40ACCEPTED0.00 sdetails
#41ACCEPTED0.00 sdetails
#42ACCEPTED0.00 sdetails
#43ACCEPTED0.00 sdetails
#44ACCEPTED0.00 sdetails
#45ACCEPTED0.00 sdetails
#46ACCEPTED0.00 sdetails
#47ACCEPTED0.00 sdetails
#48ACCEPTED0.00 sdetails
#49ACCEPTED0.00 sdetails
#50ACCEPTED0.00 sdetails
#51ACCEPTED0.00 sdetails
#52ACCEPTED0.00 sdetails
#53ACCEPTED0.00 sdetails
#54ACCEPTED0.00 sdetails
#55ACCEPTED0.00 sdetails
#56ACCEPTED0.01 sdetails
#57ACCEPTED0.08 sdetails
#58ACCEPTED0.01 sdetails
#59ACCEPTED0.10 sdetails
#60ACCEPTED0.00 sdetails
#61ACCEPTED0.12 sdetails
#62ACCEPTED0.05 sdetails
#63ACCEPTED0.01 sdetails
#64ACCEPTED0.01 sdetails
#65ACCEPTED0.24 sdetails

Code

use std::io::{self, Read};

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::c19::task3();
    // homework::hw8::task1();
    // println!("{}", "-".repeat(20));
}
// */


fn verify_sequence(s: &[char]) -> (String, usize) {
    let mut curr: String = String::new();
    let mut valid: String = String::new();
    let mut valid_index = 0;
    let mut open=0;

    for i in 0..s.len() {
        match s[i] {
            '(' => {
                open+=1;
                curr.push(s[i]);
            }
            ')' => {
                if open == 0 {
                    return (valid, valid_index)
                }
                open-=1;
                curr.push(s[i]);
                if open == 0 {
                    valid = curr.clone();
                    valid_index = i;
                }
            }
            _ => {panic!()} }
    }
    (valid, valid_index)
}

 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 mut max = String::new();

     let mut i = 0;
     while i<s.len() {
         let (curr_s, curr_i) = verify_sequence(&v[i..v.len()]);
         if curr_s.len() > max.len() {
             max = curr_s;
         }
         i += curr_i + 1;
     }

    if max.len() != 0 {
        println!("{}", max)
    } else {
        println!("-1")
    }
}

//
// fn verify_sequence(s: &[char]) -> (String, usize) {
//     let mut curr = String::new();
//     let mut valid = String::new();
//     let mut valid_index = 0;
//     let mut open=0;
//     let mut closed = 0;
//
//     for i in 0..s.len() {
//         match s[i] {
//             '(' => {
//                 open+=1;
//                 curr.push(s[i]);
//             }
//             ')' => {
//                 if closed == open {
//                     return (String::new(), open - min(open, closed))
//                 }
//                 closed+=1;
//                 curr.push(s[i]);
//                 if closed == open {
//                     valid = curr.clone();
//                     valid_index = i;
//                 }
//             }
//             _ => {panic!()} }
//     }
//     if valid.len() > 0 {
//         (valid, valid_index)
//     } else {
//         (String::new(), open - min(open, closed))
//     }
// }
//
// 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 mut max = String::new();
//     let mut previous_left_open = 0;
//
//     let mut i = 0;
//     while  {
//
//     }
//
//     for i in 0..v.len() {
//         let curr = verify_sequence(&v[i..v.len()]);
//
//         if curr.len() > max.len() {
//             max = curr;
//         }
//     }
//
//     if max.len() != 0 {
//         println!("{}", max)
//     } else {
//         println!("-1")
//     }
// }

Test details

Test 1

Verdict: ACCEPTED

input
(

correct output
-1

user output
-1

Test 2

Verdict: ACCEPTED

input
))

correct output
-1

user output
-1

Test 3

Verdict: ACCEPTED

input
((

correct output
-1

user output
-1

Test 4

Verdict: ACCEPTED

input
()

correct output
()

user output
()

Test 5

Verdict: ACCEPTED

input
(()

correct output
()

user output
()

Test 6

Verdict: ACCEPTED

input
()()

correct output
()()

user output
()()

Test 7

Verdict: ACCEPTED

input
))))

correct output
-1

user output
-1

Test 8

Verdict: ACCEPTED

input
())(

correct output
()

user output
()

Test 9

Verdict: ACCEPTED

input
(()(

correct output
()

user output
()

Test 10

Verdict: ACCEPTED

input
)))))

correct output
-1

user output
-1

Test 11

Verdict: ACCEPTED

input
())(()

correct output
()

user output
()

Test 12

Verdict: ACCEPTED

input
))(()(

correct output
()

user output
()

Test 13

Verdict: ACCEPTED

input
()(())

correct output
()(())

user output
()(())

Test 14

Verdict: ACCEPTED

input
()(())

correct output
()(())

user output
()(())

Test 15

Verdict: ACCEPTED

input
()((((

correct output
()

user output
()

Test 16

Verdict: ACCEPTED

input
(())(())((

correct output
(())(())

user output
(())(())

Test 17

Verdict: ACCEPTED

input
)))((()(((

correct output
()

user output
()

Test 18

Verdict: ACCEPTED

input
(()))(((((

correct output
(())

user output
(())

Test 19

Verdict: ACCEPTED

input
())(()())(

correct output
(()())

user output
(()())

Test 20

Verdict: ACCEPTED

input
))))))))))

correct output
-1

user output
-1

Test 21

Verdict: ACCEPTED

input
())(())(()

correct output
(())

user output
(())

Test 22

Verdict: ACCEPTED

input
)((())(()(

correct output
(())

user output
(())

Test 23

Verdict: ACCEPTED

input
()(())()()

correct output
()(())()()

user output
()(())()()

Test 24

Verdict: ACCEPTED

input
()(())((()

correct output
()(())

user output
()(())

Test 25

Verdict: ACCEPTED

input
()((((((((

correct output
()

user output
()

Test 26

Verdict: ACCEPTED

input
((((((())))))))(((((((((()))))...

correct output
(((((())))))(((((((((()))))(((...

user output
(((((())))))(((((((((()))))(((...

Test 27

Verdict: ACCEPTED

input
)))((()((((((()()))(())(()(())...

correct output
((()((((((()()))(())(()(()))((...

user output
((()((((((()()))(())(()(()))((...

Test 28

Verdict: ACCEPTED

input
(()))((((((())(((()))))(())())...

correct output
(((())((()()(((((())()))())))(...

user output
(((())((()()(((((())()))())))(...

Test 29

Verdict: ACCEPTED

input
())))))))(((((((((())))(()))))...

correct output
(((((((((())))(())))))((((((()...

user output
(((((((((())))(())))))((((((()...

Test 30

Verdict: ACCEPTED

input
))))))))))))))))))))))))))))))...

correct output
-1

user output
-1

Test 31

Verdict: ACCEPTED

input
())(())(()()()(()()()))((())((...

correct output
(())(()()()(()()()))((())(((((...

user output
(())(()()()(()()()))((())(((((...

Test 32

Verdict: ACCEPTED

input
(((((((((()))))))))((((((((())...

correct output
((((((((()))))))))

user output
((((((((()))))))))

Test 33

Verdict: ACCEPTED

input
()(())()()()(((((())))(((()())...

correct output
((((())))(((()()))((())(())())...

user output
((((())))(((()()))((())(())())...

Test 34

Verdict: ACCEPTED

input
()(())((()))(((())))((((()))))...

correct output
()(())((()))(((())))((((()))))...

user output
()(())((()))(((())))((((()))))...

Test 35

Verdict: ACCEPTED

input
()(((((((()(((((((((()())())))...

correct output
()(((((((()(((((((((()())())))...

user output
()(((((((()(((((((((()())())))...

Test 36

Verdict: ACCEPTED

input
((((((((((((())))))))))))))))(...

correct output
((((((((((((((()))))))))))))((...

user output
((((((((((((((()))))))))))))((...

Test 37

Verdict: ACCEPTED

input
)))((()((((((()()))(())(()(())...

correct output
((()((((()(()((()(())()((()())...

user output
((()((((()(()((()(())()((()())...

Test 38

Verdict: ACCEPTED

input
(()))((((((())(((()))))(())())...

correct output
((((((())(((()))))(())())())((...

user output
((((((())(((()))))(())())())((...

Test 39

Verdict: ACCEPTED

input
(()))))))))))))))(((((((((((((...

correct output
(((((((((((((((((()))))))((())...

user output
(((((((((((((((((()))))))((())...

Test 40

Verdict: ACCEPTED

input
))))))))))))))))))))))))))))))...

correct output
-1

user output
-1

Test 41

Verdict: ACCEPTED

input
())(())(()()()(()()()))((())((...

correct output
(())(()()()(()()()))((())(((((...

user output
(())(()()()(()()()))((())(((((...

Test 42

Verdict: ACCEPTED

input
))))(((((((((((((())))))))))))...

correct output
((((((((((((()))))))))))))

user output
((((((((((((()))))))))))))

Test 43

Verdict: ACCEPTED

input
()(())()()()(((((())))(((()())...

correct output
()()(((()())(()(((()(()(()(()(...

user output
()()(((()())(()(((()(()(()(()(...

Test 44

Verdict: ACCEPTED

input
()(())((()))(((())))((((()))))...

correct output
()(())((()))(((())))((((()))))...

user output
()(())((()))(((())))((((()))))...

Test 45

Verdict: ACCEPTED

input
()(((((((()(((((((((()())())))...

correct output
()(((((((()(((((((((()())())))...

user output
()(((((((()(((((((((()())())))...

Test 46

Verdict: ACCEPTED

input
((((((((((((((((((((((((((((((...

correct output
((((((((((((((((((((((((((((((...

user output
((((((((((((((((((((((((((((((...

Test 47

Verdict: ACCEPTED

input
)))((()((((((()()))(())(()(())...

correct output
(((())()((()))()())((((((()(()...

user output
(((())()((()))()())((((((()(()...

Test 48

Verdict: ACCEPTED

input
(()))((((((())(((()))))(())())...

correct output
((()))(()()((()()((((()()()(()...

user output
((()))(()()((()()((((()()()(()...

Test 49

Verdict: ACCEPTED

input
(((((((())))))))))))))))))))))...

correct output
((((((((((((((((((((((((((((((...

user output
((((((((((((((((((((((((((((((...

Test 50

Verdict: ACCEPTED

input
))))))))))))))))))))))))))))))...

correct output
-1

user output
-1

Test 51

Verdict: ACCEPTED

input
())(())(()()()(()()()))((())((...

correct output
(((()((((((()(((((()(((()(((()...

user output
(((()((((((()(((((()(((()(((()...

Test 52

Verdict: ACCEPTED

input
(((((((())))))))))))))))))))))...

correct output
((((((((((((((((((((((((((((((...

user output
((((((((((((((((((((((((((((((...

Test 53

Verdict: ACCEPTED

input
()(())()()()(((((())))(((()())...

correct output
()(())()()()(((((())))(((()())...

user output
()(())()()()(((((())))(((()())...

Test 54

Verdict: ACCEPTED

input
()(())((()))(((())))((((()))))...

correct output
()(())((()))(((())))((((()))))...

user output
()(())((()))(((())))((((()))))...

Test 55

Verdict: ACCEPTED

input
()(((((((()(((((((((()())())))...

correct output
(((())((())(())(((()(()()(()()...

user output
(((())((())(())(((()(()()(()()...

Test 56

Verdict: ACCEPTED

input
((((((((((((((((((((((((((((((...

correct output
((((((((((((((((((((((((((((((...

user output
((((((((((((((((((((((((((((((...

Test 57

Verdict: ACCEPTED

input
)))((()((((((()()))(())(()(())...

correct output
(((()))(())(())(((((()())()(()...

user output
(((()))(())(())(((((()())()(()...

Test 58

Verdict: ACCEPTED

input
(()))((((((())(((()))))(())())...

correct output
(()()(()((()(((()(((()()()()((...

user output
(()()(()((()(((()(((()()()()((...

Test 59

Verdict: ACCEPTED

input
((((((((((((((((((((((((((((((...

correct output
((((((((((((((((((((((((((((((...

user output
((((((((((((((((((((((((((((((...

Test 60

Verdict: ACCEPTED

input
))))))))))))))))))))))))))))))...

correct output
-1

user output
-1

Test 61

Verdict: ACCEPTED

input
())(())(()()()(()()()))((())((...

correct output
(()(()()()(()())(())((((((()((...

user output
(()(()()()(()())(())((((((()((...

Test 62

Verdict: ACCEPTED

input
))))))))))))))))))))))))))))))...

correct output
((((((((((((((((((((((((((((((...

user output
((((((((((((((((((((((((((((((...

Test 63

Verdict: ACCEPTED

input
()(())()()()(((((())))(((()())...

correct output
(()()((((())()()())())))((())(...

user output
(()()((((())()()())())))((())(...

Test 64

Verdict: ACCEPTED

input
()(())((()))(((())))((((()))))...

correct output
()(())((()))(((())))((((()))))...

user output
()(())((()))(((())))((((()))))...

Test 65

Verdict: ACCEPTED

input
()(((((((()(((((((((()())())))...

correct output
()(((((()()))()))()(())(((()((...

user output
()(((((()()))()))()(())(((()((...