문제 설명
단어 s의 가운데 글자를 반환하는 함수, solution을 만들어 보세요. 단어의 길이가 짝수라면 가운데 두글자를 반환하면 됩니다.
재한사항- s는 길이가 1 이상, 100이하인 스트링입니다.
"abcde" | "c" |
"qwer" | "we" |
<제출답안>
솔직히 너무 복잡해서 추론은 빨리했는데 식으로 적는데 계속 에러떠서 좀 걸림.
function solution(s) {
let place = s.length % 2 != 0? ~~(s.length /2) : s.length/2 - 1 // 홀수 : 짝수
return (place == ~~(s.length /2))? [...s].slice(place, place+1).join("") : [...s].slice(s.length/2 - 1, s.length/2 - 1 + 2).join("")
}
아래 코드처럼 가볍게 하길....
근데 간결하게 하려면 코드 많이 짜봐야함.
결국 연습밖에 답이 없단거지...ㅋㅋ
unction solution(s) {
const mid = Math.floor(s.length/2);
return s.length %2 === 1 ? s[mid] : s[mid-1]+s[mid];
}
'🗃️javascript > 프로그래머스' 카테고리의 다른 글
2차원으로 만들기(Lv.0) (0) | 2023.01.11 |
---|---|
수박수박수박수박수박수?(Lv.1)[str.repeat(횟수)] (1) | 2023.01.11 |
A로 B 만들기(Lv.0)[반복문 i번에 조건을 구성하는 변수값이 변경된다면, i+1에는 바뀐 변수값으로 조건을 따짐] (0) | 2023.01.10 |
없는 숫자 더하기(Lv.1)[문제 조건들 똑바로 읽자. includes()설명] (0) | 2023.01.10 |
팩토리얼(Lv.0)[반복을 너무 많이 돌리면 시간초과로 오류가 뜬다.] (0) | 2023.01.10 |