코딩테스트 연습 > 코딩 기초 트레이닝
문자열 배열 intStrs와 정수 k, s, l가 주어집니다. intStrs의 원소는 숫자로 이루어져 있습니다.
배열 intStrs의 각 원소마다 s번 인덱스에서 시작하는 길이 l짜리 부분 문자열을 잘라내 정수로 변환합니다. 이때 변환한 정수값이 k보다 큰 값들을 담은 배열을 return 하는 solution 함수를 완성해 주세요.
s < 100l ≤ 8k < 10lintStrs의 길이 ≤ 10,000intStrs의 원소의 길이 ≤ 120| intStrs | k | s | l | result |
|---|---|---|---|---|
| ["0123456789","9876543210","9999999999999"] | 50000 | 5 | 5 | [56789, 99999] |
// 나의 풀이
const solution = (intStrs, k, s, l) => {
// 변환한 정수값이 k보다 큰 값들만 새로운 배열에 추가
const arr = []
intStrs.map((item, idx) => {
let num = Number(item.substr(s, l))
if(num > k) arr.push(num)
})
return arr;
}
// 다른 사람의 풀이 참고
// + 연산자를 활용하여 정수 변환
function solution(intStrs, k, s, l) {
return intStrs.map((v) => +v.slice(s, s + l))
.filter((v) => v > k);
}
Number() : 문자열을 인수로 받는다.parseInt() : 문자열과 기수를 인수로 받아 정수를 반환. (like 10진수 -> 10) parseFloat() : 실수를 반환.+*1, 곱하기 1/1, 나누기 1-0, 빼기 0 const quantity = "12";
Number(quantity);
parseInt(quantity, 10); // 10진수, 2진수는 2
parseFloat(quantity);
+quantity;
quantity * 1;
quantity / 1;
quantity - 0;