[프로그래머스] 이상한 문자 만들기_JavaScript

ne_ol·2022년 1월 18일
1
post-thumbnail

문제 설명

문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.

제한 사항

  • 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
  • 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.

입출력 예

sreturn
"try hello world""TrY HeLlO WoRlD"

입출력 예 설명

"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.


기본 solution 코드

function solution(s) {
    var answer = '';
    return answer;
}

문제 풀이

//콘솔은 되는데 통과가 되지 않았던
function solution(s) {
    var x = s.split(' ');
    var answer = '';
    for (let i = 0; i < x.length; i++) {
        var result = x[i].split('')
        answer += result.map((cur, j) => j%2 ? cur.toLowerCase() : cur.toUpperCase()).join('') + " ";
    }
    return answer.trim();
}

//통과된 코드
function solution(s) {
    var x = s.split(' ');
    var answer = [];    
    for (let i = 0; i < x.length; i++) {
        answer.push(x[i].split('').map((cur, j) => j%2 ? cur.toLowerCase() : cur.toUpperCase()).join(''));
    }
  return answer.join(" ");
}

풀이 설명

고민도 많이 하고 시간도 많이 썼다. 어떻게 풀지도, 어떤 함수를 쓸지도 다 아는 상황에서 잘 풀리지 않으니 정말 답답했다. 첫 번째 풀이에서는 지인 개발자분 말씀으로는 .join뒤에 space 붙힌 게 아마 몇몇 테스트 케이스에서 걸리지 않았던 것 같다고 하셨다.
이는 내가 answer type을 string과 array로 많이 시도하며 고민했던 요소랑 일맥상통하다. 첫 번째 풀이에서는 string type의 answer에 string +string +.. 이런 식으로 접근했고, 두 번째 풀이에서는 answer array에 push하고 join으로 합쳐버렸다.
잠도 얼마 못 자고 가야했던 수영도 못 갔지만, 그래도 뿌듯하다.

사용 함수

중복


다른 풀이

function toWeirdCase(s){
  return s.toUpperCase().replace(/(\w)(\w)/g, function(a){return a[0].toUpperCase()+a[1].toLowerCase();})
}

다른 풀이 설명

  1. 사용된 함수
  • regexp
    • \w: [A-Za-z0-9_] 와 동일

(출처: https://developer.mozilla.org/ko/docs/Web/JavaScript/Guide/Regular_Expressions)

  1. 풀이
  • 나중에..
  1. 수영 못 간 게 걸리네
profile
개발되는 중입니다.

0개의 댓글