1번 문제
@ 대문자와 소문자가 섞여있는 문자열 s가 주어집니다. s에 'p'의 개수와 'y'의 개수를 비교해 같으면 True, 다르면 False를 return 하는 solution를 완성하세요. 'p', 'y' 모두 하나도 없는 경우는 항상 True를 리턴합니다. 단, 개수를 비교할 때 대문자와 소문자는 구별하지 않습니다.
예를 들어 s가 "pPoooyY"면 true를 return하고 "Pyy"라면 false를 return합니다.
- 제한 사항 -
- 문자열 s의 길이 : 50 이하의 자연수
- 문자열 s는 알파벳으로만 이루어져 있습니다.
- Solution -
function solution(s){
return (s.match(/p/gi)||[]).length == (s.match(/y/gi)||[]).length
}
match 메소드를 이용해 p와 y를 각각의 개수를 알아내고 비교하는 방법이다. 코드에서 match안에 부분은 정규표현식이다. 뒤에 논리합 연산자를 이용해 왼쪽이 없다면 비어있는 []을 받는 형식이다. 이렇게 처리해주지 않을 경우 값이 0이 아닌 undefined형태가 되므로 오류가 난다.
2번 문제
@ 어떤 정수들이 있습니다. 이 정수들의 절댓값을 차례대로 담은 정수 배열 absolutes와 이 정수들의 부호를 차례대로 담은 불리언 배열 signs가 매개변수로 주어집니다. 실제 정수들의 합을 구하여 return 하도록 solution 함수를 완성해주세요.
- 제한 사항 -
- absolutes의 길이는 1 이상 1,000 이하입니다.
- absolutes의 모든 수는 각각 1 이상 1,000 이하입니다.
- signs의 길이는 absolutes의 길이와 같습니다.
- signs[i] 가 참이면 absolutes[i] 의 실제 정수가 양수임을, 그렇지 않으면 음수임을 의미합니다.
- Solution -
function solution(absolutes, signs) {
let sum = 0;
for(let i=0; i<absolutes.length; i++) {
signs[i] ? sum+=absolutes[i] : sum-=absolutes[i]
}
return sum
}
sum의 초기값을 0으로 설정하고 for문 안에 삼항 연산자를 이용해 더하는 방식이다. absolutes의 index 값보다 작을 때 계속해서 for문을 도는 형식이며 sign[i]가 true일 경우 sum에 absolutes의 값을 더하고 false일 경우 sum에 absolutes의 값을 뺀다.
'JavaScript Dev. > Javascript' 카테고리의 다른 글
2023.04.12 - <2주차 과제> (0) | 2023.04.12 |
---|---|
9. Map과 Set (0) | 2023.04.10 |
8. ES6 문법 & 일급 객체로서의 함수 (0) | 2023.04.09 |
7. 반복문 (0) | 2023.04.08 |
6. 배열, 객체 (0) | 2023.04.08 |