Submission details
Task:Sulkulauseke
Sender:ollpu
Submission time:2025-12-20 16:21:09 +0200
Language:C++ (C++20)
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 <bits/stdc++.h>
using namespace std;
 
#ifdef LOCAL
#define D(x) {x;}
#else
#define D(x)
#endif
#define rep(i, a, b) for(int i = a; i < (b); ++i)
#define all(x) begin(x), end(x)
#define sz(x) (int)(x).size()
 
using ll = long long;
using pii = pair<int, int>;
using vi = vector<int>;
 
int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin.exceptions(cin.failbit);
    string s;
    cin >> s;
    int n = sz(s);
    int rmin[n+1];
    int cnt = 0;
    for (int i = n-1; i >= 0; --i) {
        if (s[i] == ')') cnt++;
        else if (s[i] == '(') cnt--;
        else cnt -= cnt > 0;
        if (cnt < 0) cnt = 0;
        rmin[i] = cnt;
    }
    rmin[n] = 0;
    cnt = 0;
    for (int i = 0; i < n; ++i) {
        if (s[i] == ')') cnt--;
        else if (s[i] == '(') cnt++;
        else {
            if (cnt && rmin[i+1] < cnt) {
                cnt--;
                s[i] = ')';
            } else {
                cnt++;
                s[i] = '(';
            }
        }
        if (cnt < 0) {
            cout << "IMPOSSIBLE\n";
            return 0;
        }
    }
    if (cnt != 0) cout << "IMPOSSIBLE\n";
    else cout << s << endl;
}

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