FrontEnd/프로그래머스

[JS] 쿠키 구입

정_민_규 2024. 3. 5. 18:40
728x90

투포인터를 활용하여 해결하였다!

 

https://school.programmers.co.kr/learn/courses/30/lessons/49995

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 

특점 점을 기준으로 왼쪽과 오른쪽으로 포인터를 보내면서 합을 비교하였다.

 

특정 점을 m이라고 두자.

 

m, m+1 을 각각 left,right로 둔다.

 

left===right 라면 최대로 가질 수 있는 과자의 값을 갱신하고 left,right를 좌,우로 보낸다.

만약 left>right라면 오른쪽으로 과자를 더 가져간다.

left<right라면 왼쪽으로 과자를 더가져간다.

 

위 세가지 경우를 배열의 범위를 넘지 않는 선까지 반복한다.

 

2000개의 경우의 수 이므로 충분히 통과될 것이라 예상했고 실제로도 통과했다.

 

 

 

 

 

 

 

function solution(cookie) {
  const getCnt = (i) => {
    let j = i + 1;
    if (!(0 <= i && j < cookie.length)) return 0;
    //투포인터 사용
    let left = cookie[i];
    let right = cookie[j];
    let ret = 0;
    while (0 <= i && j < cookie.length) {
      if (left === right) {
        ret = left;
        if (0 <= --i && ++j < cookie.length) {
          left += cookie[i];
          right += cookie[j];
        }
      } else if (left > right && ++j < cookie.length) right += cookie[j];
      else if (0 <= --i) left += cookie[i];
    }
    return ret;
  };

  let ret = 0;
  for (let i = 0; i < cookie.length; i++) {
    const cnt = getCnt(i);
    if (ret < cnt) ret = cnt;
  }
  return ret;
}
728x90