본문 바로가기
알고리즘

프로그래머스 1단계 : 이상한 문자 만들기

by 코터틀 2022. 12. 1.
반응형

프로그래머스 1단계 : 이상한 문자 만들기

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



※ 제한사항

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

※ 입출력 예

s return
"try hello world" "TrY HeLlO WoRlD"

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

x변수에 s문자열을 단어 단위로 끊어 배열로 저장합니다. for문을 짝수일 경우 대문자를 answer에 추가하고 홀수면 소문자를 추가해줍니다. 그러면 문자 변환은 완료지만, 공백이 없으므로 for문 안에 for문이 한번 완료될 때 공백을 추가해주면 됩니다.

※ 다른 사람의 풀이

function toWeirdCase(s){
    //함수를 완성해주세요
    return s.toUpperCase().replace(/(\w)(\w)/g, function(a){return a[0].toUpperCase()+a[1].toLowerCase();})
  
  }

깔끔한 풀이인데 정규식 표현은 너무 어렵네요. 설명은 구글링에 맡기겠습니다.
반응형

댓글


광고 준비중입니다.