알고리즘&자료구조

[Greedy][javascript] 백준 1541번

ooin 2024. 2. 6. 11:35
반응형

1541번: 잃어버린 괄호 (acmicpc.net)

 

1541번: 잃어버린 괄호

첫째 줄에 식이 주어진다. 식은 ‘0’~‘9’, ‘+’, 그리고 ‘-’만으로 이루어져 있고, 가장 처음과 마지막 문자는 숫자이다. 그리고 연속해서 두 개 이상의 연산자가 나타나지 않고, 5자리보다

www.acmicpc.net

문제

세준이는 양수와 +, -, 그리고 괄호를 가지고 식을 만들었다. 그리고 나서 세준이는 괄호를 모두 지웠다.

그리고 나서 세준이는 괄호를 적절히 쳐서 이 식의 값을 최소로 만들려고 한다.

괄호를 적절히 쳐서 이 식의 값을 최소로 만드는 프로그램을 작성하시오.

입력

첫째 줄에 식이 주어진다. 식은 ‘0’~‘9’, ‘+’, 그리고 ‘-’만으로 이루어져 있고, 가장 처음과 마지막 문자는 숫자이다. 그리고 연속해서 두 개 이상의 연산자가 나타나지 않고, 5자리보다 많이 연속되는 숫자는 없다. 수는 0으로 시작할 수 있다. 입력으로 주어지는 식의 길이는 50보다 작거나 같다.

출력

첫째 줄에 정답을 출력한다.

const fs = require ('fs').readFileSync('/dev/stdin');
const input = fs.toString();

const minusLocation = input.indexOf('-');
if (minusLocation === -1) {
    console.log(input.split(/[\+-]/).map(x => parseInt(x)).reduce((acc, x) => acc += x));
} else {
    const front = input.slice(0, minusLocation).split(/[\+-]/).map(x => parseInt(x)).reduce((acc, x) => acc += x)
    const back = input.slice(minusLocation+1).split(/[\+-]/).map(x => parseInt(x)).reduce((acc, x) => acc += x)
    console.log(front - back);
}

 

 

시간/메모리 제한을 보고 '-', '+' 로 문자열을 나눈후 계산결과를 비교해도 풀수 있을것 같다는 생각이 들었지만 좀더 깔끔한 풀이를 고민하다가 다른 블로그를 보고 참고하여 풀이하였습니다.

 

첫번째 마이너스 부호를 찾아서 앞/뒤로 나눈 후 빼주면 최솟값이 나오고 모두 + 인 경우에는 그냥 전부 더해주는 식으로 풀이하였습니다.

 

split 메소드를 사용하면서 정규식을 사용할 생각은 못했는데 이 문제를 풀면서 정규식도 사용가능한 것을 알게되었습니다.

 

아래 블로그를 참고하여 작성하였습니다.

참고: [백준 1541] 잃어버린 괄호 with Node.js — 한 걸음씩 (tistory.com)

반응형

'알고리즘&자료구조' 카테고리의 다른 글

[자료구조] LinkedList 란?  (0) 2024.03.03
[정렬] 버블 정렬  (0) 2024.02.21
[정렬] 퀵 정렬  (1) 2024.02.07
[Greedy][javascript] 백준 11047번  (2) 2024.02.05
[Greedy] 그리디 알고리즘 (1)  (2) 2024.02.05