반응형
프로그래머스 1단계 : 이상한 문자 만들기
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
※ 제한사항
문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
첫 번째 글자는 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();})
}
깔끔한 풀이인데 정규식 표현은 너무 어렵네요. 설명은 구글링에 맡기겠습니다.
반응형
'알고리즘' 카테고리의 다른 글
프로그래머스 0단계 : 피자 나눠 먹기 (2) | 2022.12.04 |
---|---|
프로그래머스 1단계 : 예산 (1) | 2022.12.02 |
프로그래머스 1단계 : 2016년 (2) | 2022.11.30 |
프로그래머스 1단계 : 최대공약수와 최소공배수 (3) | 2022.11.29 |
프로그래머스 1단계 : 3진법 뒤집기 (2) | 2022.11.28 |
댓글