Вам дана строка, состоящая из символов 0123456789+*()
. Вы можете предположить, что строка всегда является допустимым математическим выражением.
Ваша задача - убрать лишние скобки, предполагая, что умножение имеет более высокий приоритет, чем сложение.
Скобки следует удалять только тогда, когда они не нужны конструктивно :
- из-за умножения более высокого приоритета:
3+(4*5)
=>3+4*5
- из-за умножения или сложения ассоциативности:
3*(4*5)
=>3*4*5
- когда они избыточны вокруг выражения:
3*((4+5))
=>3*(4+5)
Скобки должны быть сохранены, когда они могут быть упрощены из-за определенных числовых значений:
1*(2+3)
не должно быть упрощено до1*2+3
0*(1+0)
не должно быть упрощено до0*1+0
Примеры:
(4*12)+11 ==> 4*12+11
(1+2)*3 ==> (1+2)*3
3*(4*5) ==> 3*4*5
((((523)))) ==> 523
(1+1) ==> 1+1
1*(2*(3+4)*5)*6 ==> 1*2*(3+4)*5*6
1*(2+3) ==> 1*(2+3)
0*(1+0) ==> 0*(1+0)
(((2+92+82)*46*70*(24*62)+(94+25))+6) ==> (2+92+82)*46*70*24*62+94+25+6
1*(2*(3+4)*5)*6
должен быть интересный тестовый сценарий (для которого мое решение в настоящее время не удается).
(2+2)*1