찰리의 이야기

Javascript 이상한 문자 만들기 본문

찰리: 코딩 연습

Javascript 이상한 문자 만들기

쨜리 2021. 9. 15. 12:40
반응형

Javascript 이상한 문자 만들기

 

 

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

제한 사항

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

입출력 예

string / return

"try hello world" "TrY HeLlO WoRlD"

 

주어진 코드  

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

우선 띄어쓰기를 기준으로 각각의 규칙이 적용되어야 한다는 점에서

우선 split(" ")으로 띄어쓰기로 끊어서 나누어 반복문을 돌려야겠다는 생각이 들었습니다.

그 다음은 각 단어마다 다시 인덱스마다 규칙을 적용해야하기 때문에

중첩 반복문이 되어야 하지 않을까 싶었습니다. 

function solution(s) {
    let arr = s.split(" ");
    let answer = "";
    for(let i=0; i<arr.length; i++){
        for(let j=0; j<arr[i].length; j++){
            if(j % 2 !== 0){
                answer = answer + arr[i][j].toLowerCase();
            }else{
                answer = answer + arr[i][j].toUpperCase();
            }
        }
        if(i < arr.length - 1){
                answer = answer + " ";
            }
    }
    return answer;
}

 짝수 홀수 규칙이 있었기 때문에 간단히 분기화 해줄 수 있었습니다.

 

여기까지가 제 풀이 방법이고,

다른 풀이법도 살펴보았습니다.

 

function solution(s) {
    return s.split(' ').map(el => el.split('').map((el, index) => index % 2 == 0 ? el.toUpperCase() : el.toLowerCase()).join('')).join(' ');
}

우선 띄어쓰기를 기준으로 배열로 만든 것 까지는 같습니다.

이때 각 엘리먼트들에 map()을 중첩으로 이용했습니다.

그리고 중첩을 벗어날 때, 다시금 join()으로 연결시키는 방법입니다.

 

split() 으로 쪼개고, join()으로 붙인다.

배열 탐색을 중첩으로 해야할 때 참고하면 좋겠습니다.

물론, 속도에 있어서는 거의 비슷할 것 같기는 합니다. 

 

Javascript 이상한 문자 만들기

반응형
Comments