프로그램 명: coci_zagrade
제한시간: 1 초
[요약] 입력을 제외한 매치된 괄호들을 임의로 없애서 만들 수 있는 모든 경우를 오름차순으로 출력한다.
** 괄호 '(', ')' 는 아스키코드가 숫자보다 낮다.
Mirko was bored at his chemistry class, so he played Bomb Switcher on his cell phone. Unfortunately, he was spotted and was given a ridiculously heavy assignment for homework. For a given valid math expression with brackets, he must find all different expressions that can be obtained by removing valid pairs of brackets from the original expression. Two expressions are different if there is a character at which they differ.
For example, given (2+(2*2)+2), one can get (2+2*2+2), 2+(2*2)+2, and 2+2*2+2. (2+2*2)+2 and 2+(2*2+2) can't be reached, since we would have to remove pairs of brackets that are not valid. More than one pairs of brackets can surround the same part of the expression.
입력
The first and only line of input contains one valid mathematical expression composed of nonnegative integers, basic arithmetic operations denoted with characters .+., .*., .-. and ./., and brackets .(. and .)..
Given expression won.t have more than 200 characters, and will have at least one, and no more than 10 pairs of brackets. Each expression is guaranteed to have at least one pair of brackets.
출력
Output all different expressions that can be obtained by removing valid pairs of brackets, sorted lexicographically.
입출력 예
input
(0/(0))
output
(0/0)
0/(0)
0/0
input
(2+(2*2)+2)
output
(2+2*2+2)
2+(2*2)+2
2+2*2+2
input
(1+(2*(3+4)))
output
(1+(2*3+4))
(1+2*(3+4))
(1+2*3+4)
1+(2*(3+4))
1+(2*3+4)
1+2*(3+4)
1+2*3+4
출처:coci 2012 3/6
요약:Fate
[질/답]
[제출 현황]
[푼 후(2)]