Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 자바스크립트
- 모두싸인마케팅
- atomichabits
- 모두싸인마케터
- 갤럭시노트20
- 아이폰
- map
- 아주작은습관의힘
- 코딩테스트
- 모두의사인
- 알고리즘
- 전자계약솔루션
- 전자계약시스템
- 아이폰13
- 아이폰12
- 독서리뷰
- 좋은습관
- 블록체인
- 옥소폴리틱스
- 전자계약서비스
- javascript
- 모두싸인
- 마케팅
- 독후감
- 온라인계약
- 전자계약서
- 습관
- 자릿수더하기
- 전자계약
- 모두사인
Archives
- Today
- Total
찰리의 이야기
Javascript 문자열 내 p와 y의 개수 본문
반응형
Javascript 문자열 내 p와 y의 개수
대문자와 소문자가 섞여있는 문자열 s가 주어집니다. s에 'p'의 개수와 'y'의 개수를 비교해 같으면 True, 다르면 False를 return 하는 solution를 완성하세요. 'p', 'y' 모두 하나도 없는 경우는 항상 True를 리턴합니다. 단, 개수를 비교할 때 대문자와 소문자는 구별하지 않습니다. 예를 들어 s가 "pPoooyY"면 true를 return하고 "Pyy"라면 false를 return합니다.
제한사항
- 문자열 s의 길이 : 50 이하의 자연수
- 문자열 s는 알파벳으로만 이루어져 있습니다.
입출력 예
s / return
sanswer
"pPoooyY" | true |
"Pyy" | false |
어떻게하면 쉽게 그리고 잘 풀수 있을지 고민하느라
시간을 많이 보낸 문제였습니다.
사실 문자열을 소문자로 바꾼 다음 p와 y의 수를 센 다음
if문으로 분기화하면 쉽게 풀릴 문제입니다.
결국은 쉬운 방법으로 접근했습니다.
function solution(s){
let lowerS = s.toLowerCase();
let pCount = 0;
let yCount = 0;
for(let i=0; i<s.length; i++){
if(s[i] === "p"||s[i] === "P"){
pCount++;
}else if(s[i] === "y"|| s[i] === "Y"){
yCount++;
}
}
return pCount === yCount ? true : false;
}
여기까지가 제가 푼 방법이고,
다른 풀이법도 찾아봤습니다.
function solution(s){
return [...s.toLowerCase()].reduce((acc, cur) => {
if(cur ==='p') return acc + 1;
else if(cur ==='y') return acc - 1;
return acc;
}, 0) ? false : true;
}
reduce를 이용했습니다.
결국은 reduce 그리고 reducer 함수는
acc값으로 누적값을 가지는 것이다보니,
어떤 수를 count 하는 용도로도 사용할 수 있다는 점을 알 수 있었습니다.
배열 카운트를 할 때 reduce를 활용해보자!
Javascript 문자열 내 p와 y의 개수
반응형
'찰리: 코딩 연습' 카테고리의 다른 글
Javascript 문자열 내 마음대로 정렬하기 (0) | 2021.09.24 |
---|---|
Javascript 문자열 내림차순으로 배치하기 (0) | 2021.09.22 |
Javascript 문자열 다루기 기본 (0) | 2021.09.21 |
Javascript 수박수박수박수박수박수? (0) | 2021.09.18 |
Javascript 시저 암호 (0) | 2021.09.16 |
Comments