किसी ने हमें एक स्ट्रिंग दी है, लेकिन सभी ब्रैकेट जैसे चरित्रों को सामान्य लोगों में बदल दिया गया है, और हम नहीं जानते कि कौन से थे, या यहां तक कि कितने थे। हम सभी जानते हैं कि यदि L1,L2,L3,...,LN
अलग-अलग प्रकार के बाएँ कोष्ठक R1,R2,R3,...,RN
थे और अलग-अलग प्रकार के दाएँ कोष्ठक थे, तो सभी विशिष्ट (2N अलग कोष्ठक वर्ण) होने के कारण, यदि यह (+ सामान्य स्ट्रिंग समाकलन) है तो एक स्ट्रिंग मान्य होगी।
L1+X+R1
,,L2+X+R2
...,LN+X+RN
जहांX
एक वैध स्ट्रिंग है,X+Y
, जहांX
औरY
मान्य तार हैं,कोई भी एकल वर्ण जो ब्रैकेट वर्ण नहीं है।
खाली तार
हम जानते हैं कि उन्होंने ब्रैकेट बदलने से पहले एक वैध स्ट्रिंग के साथ शुरुआत की थी, और उन्होंने उन्हें किसी भी वर्ण में नहीं बदला जो पहले से ही स्ट्रिंग में मौजूद थे। प्रत्येक ब्रैकेट के लिए कम से कम एक जोड़ी मौजूद थी। क्या आप पुनर्निर्माण कर सकते हैं कि कौन से वर्ण मूल रूप से बाएं और दाएं ब्रैकेट जोड़े थे ( दिए गए शर्तों को देखें Li
और Ri
उनका पालन करें)?
उन पात्रों के जोड़े को आउटपुट करें जो ब्रैकेट थे। उदाहरण के लिए, यदि (){}[]
वास्तव में ब्रैकेट वर्ण थे , तो आप आउटपुट (){}[]
या {}[]()
या [](){}
, आदि कर सकते हैं। स्ट्रिंग के लिए ऐसा करने के कई तरीके हो सकते हैं, आपको केवल एक को वापस करने की आवश्यकता है जैसे कि अधिक जोड़े के साथ कोई ब्रैकेट असाइनमेंट नहीं है (उदाहरण देखें)। ध्यान दें कि आउटपुट स्ट्रिंग में हमेशा एक समान लंबाई होनी चाहिए।
उदाहरण:
abcc
- c
एक ब्रैकेट नहीं हो सकता है, क्योंकि दो घटनाओं के साथ कोई अन्य चरित्र नहीं है, लेकिन ab
एक ब्रैकेट जोड़ी हो सकती है, इसलिए आप बिल्कुल आउटपुट करेंगे ab
।
fffff
- अधिकांश एक वर्ण वाले किसी भी तार में ब्रैकेट नहीं हो सकते, इसलिए आप खाली स्ट्रिंग या आउटपुट कुछ भी नहीं लौटाएंगे।
aedbedebdcecdec
- इस स्ट्रिंग में कोई ब्रैकेट नहीं हो सकता है क्योंकि 1 ए, 2 बीएस, 3 सीएस, 4 डीएस, और 5 एस है, इसलिए कोई भी दो अक्षर समान संख्या में नहीं होते हैं, जिसे ब्रैकेट्स की आवश्यकता होती है।
abcd
- संभव कार्य कर रहे हैं ab
, cd
, abcd
, cdab
, adbc
, bcad
, ac
, ad
, bc
और bd
, (और साथ ही खाली काम है, जो उन सभी को है के रूप में), लेकिन आप सबसे लंबे समय तक कार्य में से एक लौटना चाहिए, ताकि आप लौटना चाहिए abcd
, cdab
, adbc
, या bcad
।
aabbcc
, abc
- इन दोनों ab
, ac
और bc
मान्य जोड़ों के रूप में। आपको इनमें से एक जोड़ी को वापस करना होगा, जो मायने नहीं रखता है।
abbac
- ए और बी में एक ही वर्ण गणना है, लेकिन वे वास्तव में काम नहीं कर सकते हैं, क्योंकि उनमें से एक दूसरे के सभी घटनाओं के बाएं और दाएं दोनों में होता है। कुछ भी नहीं लौटाया।
aabcdb
- cd
और ab
सटीक दो ब्रैकेट जोड़े हैं, इसलिए उत्पादन या तो cdab
या abcd
।
abcdacbd
- केवल एक जोड़ी एक बार में प्राप्त किया जा सकता है, लेकिन ab
, ac
, bd
, cd
, और ad
संभव जोड़े के सभी आप लौट सकते हैं कर रहे हैं। कोई फर्क नहीं पड़ता कि आप कौन सी जोड़ी चुनते हैं, इसका एक उदाहरण है जहां एक एकल अन्य वर्ण इसके भीतर है, जो किसी भी अन्य जोड़े को प्रतिबंधित करता है, सिवाय उस मामले में ad
, जहां अन्य जोड़े bc
और cb
अकेले अकेले संभव नहीं हैं, और इसलिए यह संभव नहीं हो सकता है के साथ ad
।
यह कोड गोल्फ है, इसलिए बाइट्स जीत में सबसे छोटा कोड है। यदि आपकी भाषा के लिए इनपुट STDIN से संभव है। यदि यह संभव नहीं है, तो अपने उत्तर में इनपुट पद्धति को इंगित करें।
abcd
, आउटपुटadbc
भी स्वीकार्य होगा, है ना?