본문 바로가기
알고리즘 공부하기

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

by 코딩 척척학사 2022. 11. 27.
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" 를 리턴합니다.

🍞 문제 풀이

반복문과 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

댓글


HTML이 적힌 썸네일 이미지
CSS가 적힌 썸네일 이미지
JAVASCRIPT가 적힌 썸네일 이미지

JAVASCRIPT

자세히 보기