728x90
프로그래머스 1단계 - 이상한 문자 만들기
🍞 문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다.
각 단어는 하나 이상의 공백문자로 구분되어 있습니다.
각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
🍞 제한 조건
문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
🍞 입출력 예
s | return |
---|---|
"try hello world" | "TrY HeLlO WoRlD" |
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다.
각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다.
따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다.
따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
🍞 문제 풀이
반복문과 toUpperCase(), toLowerCase()를 활용하였습니다. 홀수번째 수는 소문자여야 한다는 점도 잊으면 안됩니다.
function solution(s) {
var answer = [];
let arr = s.split(' ');
for( x in arr){
let str = [];
for( i in arr[x]){
i%2 == 0 ? str.push(arr[x][i].toUpperCase()) : str.push(arr[x][i].toLowerCase());
}
answer.push(str.join(''))
}
return answer.join(' ');
}
🍞 다른 이의 풀이
map문을 사용하면 간편하게 요소와 인덱스를 모두 불러올 수 있습니다.
2
const solution = s => s.split(" ").map(x => x.split('').map((c, i) => c = i % 2 === 0 ? c.toUpperCase() : c.toLowerCase()).join("")).join(" ");
728x90
'알고리즘 공부하기' 카테고리의 다른 글
프로그래머스 1단계 - 3진법 뒤집기 (1) | 2022.11.29 |
---|---|
프로그래머스 1단계 - 예산 (2) | 2022.11.28 |
프로그래머스 1단계 - 같은 숫자는 싫어 (1) | 2022.11.27 |
프로그래머스 1단계 - 최대공약수와 최소공배수 (2) | 2022.11.25 |
프로그래머스 1단계 - 직사각형 별찍기 (1) | 2022.11.24 |
댓글