저장을 습관화

프로그래머스 LV.0 문자열 바꿔서 찾기 본문

코딩 테스트/프로그래머스 - 자바스크립트

프로그래머스 LV.0 문자열 바꿔서 찾기

ctrs 2023. 9. 16. 23:28

프로그래머스 LV.0 문자열 바꿔서 찾기

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

 

프로그래머스

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

programmers.co.kr

 

1. 문제 명

문자열 바꿔서 찾기


2. 문제 설명

문자 "A"와 "B"로 이루어진 문자열 myString과 pat가 주어집니다. myString의 "A"를 "B"로, "B"를 "A"로 바꾼 문자열의 연속하는 부분 문자열 중 pat이 있으면 1을 아니면 0을 return 하는 solution 함수를 완성하세요.


3. 제한 사항

- 1 ≤ myString의 길이 ≤ 100

- 1 ≤ pat의 길이 ≤ 10

- myString과 pat는 문자 "A"와 "B"로만 이루어진 문자열입니다.


4. 예시

myString pat result
"ABBAA" "AABB" 1
"ABAB" "ABAB" 0


5. 기본 제공 코드

function solution(myString, pat) {
    var answer = 0;
    return answer;
}


6. 제출한 내 답

const solution = (myString, pat) => {
  return +[...myString]
    .map((v) => {
      return v === "A" ? (v = "B") : (v = "A");
    })
    .join("")
    .includes(pat);
};

 

6-2. VSC에 작성한 내용

const solution = (myString, pat) => {
  return +[...myString]
    .map((v) => {
      return v === "A" ? (v = "B") : (v = "A");
    })
    .join("")
    .includes(pat);
};

// 테스트
console.log(solution("ABBAA", "AABB"));
console.log(solution("ABAB", "ABAB"));


7. 특이사항

없음


8. 다른 사람이 작성한 답

8-1.

const solution = (myString, pat) => [...myString].map(v => v === 'A' ? 'B' : 'A').join('').includes(pat) ? 1 : 0