목차
반응형
문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 조건
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
나의 풀이
function solution(s) {
let answer = '';
let words = s.split(' ');
for (let i = 0; i < words.length; i++) {
for (let j = 0; j < words[i].length; j++) {
if (j % 2 === 0) {
answer += words[i][j].toUpperCase();
} else {
answer += words[i][j].toLowerCase();
}
}
if (i < words.length - 1) {
answer += ' ';
}
}
return answer;
}
다른 풀이
function toWeirdCase(s){
return s.toUpperCase().replace(/(\w)(\w)/g, function(a){return a[0].toUpperCase()+a[1].toLowerCase();})
}
마무리
문자열을 입력받아 단어 하나하나 탐색해서 상황에 맞게 반환하는 문제다.
let answer = '';
let words = s.split(' ');
문자열을 입력받아 공백을 기준으로 단어를 나누어 배열에 저장한다.
for (let i = 0; i < words.length; i++) {
for (let j = 0; j < words[i].length; j++) {
배열에 저장된 단어들을 하나씩 탐색하며 현재 탐색중인 단어의 길이만큼 반복한다.
if (j % 2 === 0) {
answer += words[i][j].toUpperCase();
}
현재 탐색중인 문자가 짝수번째인 경우 대문자로 변환하여 결과값에 추가한다.
else {
answer += words[i][j].toLowerCase();
}
현재 탐색중인 문자가 홀수번째인 경우 소문자로 변환하여 결과값에 추가한다.
if (i < words.length - 1) {
answer += ' ';
}
현재 탐색중인 단어가 마지막 단어가 아닌 경우 결과값에 공백을 추가한다.
return answer;
결과값을 반환한다.
다른사람의 풀이는.. 정규표현식과 메소드를 사용해서 작성했는데 속도는 내가 푼 방법보다 느리다.
그래도 다양한 풀이법을 보면 생각의 다양성이 생기지 않을까.
반응형