Submission details
Task:Sulkulauseke
Sender:sharph2
Submission time:2025-12-20 15:07:24 +0200
Language:C++ (C++17)
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED20
#2ACCEPTED30
#3ACCEPTED50
Test results
testverdicttimegroup
#1ACCEPTED0.00 s1, 2, 3details
#2ACCEPTED0.00 s1, 2, 3details
#3ACCEPTED0.00 s1, 2, 3details
#4ACCEPTED0.00 s1, 2, 3details
#5ACCEPTED0.00 s1, 2, 3details
#6ACCEPTED0.00 s1, 2, 3details
#7ACCEPTED0.00 s1, 2, 3details
#8ACCEPTED0.00 s1, 2, 3details
#9ACCEPTED0.00 s1, 2, 3details
#10ACCEPTED0.00 s1, 2, 3details
#11ACCEPTED0.00 s1, 2, 3details
#12ACCEPTED0.00 s1, 2, 3details
#13ACCEPTED0.00 s2, 3details
#14ACCEPTED0.00 s2, 3details
#15ACCEPTED0.00 s2, 3details
#16ACCEPTED0.00 s2, 3details
#17ACCEPTED0.00 s2, 3details
#18ACCEPTED0.01 s3details
#19ACCEPTED0.01 s3details
#20ACCEPTED0.01 s3details
#21ACCEPTED0.01 s3details
#22ACCEPTED0.01 s3details
#23ACCEPTED0.01 s3details
#24ACCEPTED0.01 s3details
#25ACCEPTED0.00 s2, 3details
#26ACCEPTED0.01 s3details
#27ACCEPTED0.00 s2, 3details
#28ACCEPTED0.01 s3details
#29ACCEPTED0.00 s2, 3details
#30ACCEPTED0.01 s3details

Code

#include <iostream>
#include <climits>
#include <cmath>
#include <map>
#include <set>
#include <vector>

using namespace std;

int main() {
    cin.sync_with_stdio(false);
    cin.tie(nullptr);

    string S;
    cin >> S;

    int n = S.size();

    vector<int> summa(n + 1);
    summa[n] = 0;
    for(int i = n - 1; i >= 0; --i) {
        summa[i] = summa[i + 1];
        if(S[i] == '(') {
            ++summa[i];
        }
        if(S[i] == ')' || S[i] == '?') {
            --summa[i];
        }
    }

    int x = 0;
    for(int i = 0; i < n; ++i) {
        if(S[i] == '(') {
            ++x;
        }
        if(S[i] == ')') {
            --x;
        }
        if(S[i] == '?') {
            if(x + 1 + summa[i + 1] <= 0) {
                ++x;
                S[i] = '(';
            } else {
                --x;
                S[i] = ')';
            }
        }
        if(x < 0) {
            cout << "IMPOSSIBLE\n";
            return 0;
        }
    }
    if(x != 0) {
        cout << "IMPOSSIBLE\n";
        return 0;
    }

    cout << S << "\n";
    return 0;
}

Test details

Test 1

Group: 1, 2, 3

Verdict: ACCEPTED

input
?

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 2

Group: 1, 2, 3

Verdict: ACCEPTED

input
??

correct output
()

user output
()

Test 3

Group: 1, 2, 3

Verdict: ACCEPTED

input
(()

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 4

Group: 1, 2, 3

Verdict: ACCEPTED

input
((()

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 5

Group: 1, 2, 3

Verdict: ACCEPTED

input
())(

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 6

Group: 1, 2, 3

Verdict: ACCEPTED

input
)???

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 7

Group: 1, 2, 3

Verdict: ACCEPTED

input
()?(

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 8

Group: 1, 2, 3

Verdict: ACCEPTED

input
()(())(())

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

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

Test 9

Group: 1, 2, 3

Verdict: ACCEPTED

input
?)(())(()?

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

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

Test 10

Group: 1, 2, 3

Verdict: ACCEPTED

input
(?))?(()))

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

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

Test 11

Group: 1, 2, 3

Verdict: ACCEPTED

input
(?)((?????

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

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

Test 12

Group: 1, 2, 3

Verdict: ACCEPTED

input
??????????

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

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

Test 13

Group: 2, 3

Verdict: ACCEPTED

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

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

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

Test 14

Group: 2, 3

Verdict: ACCEPTED

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

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

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

Test 15

Group: 2, 3

Verdict: ACCEPTED

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

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

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

Test 16

Group: 2, 3

Verdict: ACCEPTED

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

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

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

Test 17

Group: 2, 3

Verdict: ACCEPTED

input
??????????????????????????????...

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

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

Test 18

Group: 3

Verdict: ACCEPTED

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

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

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

Test 19

Group: 3

Verdict: ACCEPTED

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

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

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

Test 20

Group: 3

Verdict: ACCEPTED

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

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

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

Test 21

Group: 3

Verdict: ACCEPTED

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

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

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

Test 22

Group: 3

Verdict: ACCEPTED

input
??????????????????????????????...

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

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

Test 23

Group: 3

Verdict: ACCEPTED

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

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

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

Test 24

Group: 3

Verdict: ACCEPTED

input
??????????????????????????????...

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

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

Test 25

Group: 2, 3

Verdict: ACCEPTED

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

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 26

Group: 3

Verdict: ACCEPTED

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

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 27

Group: 2, 3

Verdict: ACCEPTED

input
)?????????????????????????????...

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 28

Group: 3

Verdict: ACCEPTED

input
)?????????????????????????????...

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 29

Group: 2, 3

Verdict: ACCEPTED

input
??????????????????????????????...

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 30

Group: 3

Verdict: ACCEPTED

input
??????????????????????????????...

correct output
IMPOSSIBLE

user output
IMPOSSIBLE