일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- align-iitems
- 화살표함수 기본 개념
- Promise Chaining
- 재귀적으로 생각하기
- Instanc
- 객체지향 프로그래밍 특징
- async/await
- class
- 다형성 (polymorphism)
- 첫번째 미니 프로잭트
- flex-direction
- 추상화 (abstraction)
- props비구조화 할당
- 재귀함수 탬플릿
- 캡슐화 (encapsulation)
- justfiy-content
- 상속 (inheritance)
- 얕은복사와 깊은 복사
- probs
- css 정리
- 조건문
- string
- 참조자료형
- 클래스 문법 구조
- Promise all
- display
- Math.floor()
- 문자열을 객체로 만드는법
- probs.children
- align-content
Archives
- Today
- Total
희락코딩
프로그래머스 1단계 - 제일 작은 수 제거하기 본문
728x90
반응형
#문제
정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다.
#제한 사항
arr은 길이 1 이상인 배열입니다.
인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다.
#입출력예시
arr | return |
[4,3,2,1] | [4,3,2] |
[10] | [-1] |
# 문제 풀이 및 코드작성
처음엔 솔트 정렬을 활용해서 제일 작은 수를 끝에다 배치하고 슬라이스를 활용해서 제일 작은 값 빼고 나머지가 출력 될수 있도록 로직을 작성하였습니다..... 테스트 케이스는 통과하였지만 제출이 안되고 오류가 생겼습니다 ㅠㅠ
1
2
3
4
5
6
7
8
9
10
11
|
function solution(arr) {
if(arr.length <= 1){
return [-1]
}
let restArr = arr.sort((a,b)=>b-a)
return restArr.slice(0,-1)
}
|
cs |
그래서 아래에 코드 처럼 정석으로 풀었더니 통과 및 제출도 가능해졌습니다..
1
2
3
4
5
6
7
8
9
10
11
12
13
|
function solution(arr) {
if(arr.length <= 1){
return [-1]
}
let arrMin = Math.min(...arr)
let result = []
for(let i in arr){
if(arrMin !== arr[i]){
result.push(arr[i])
}
}
return result
}
|
cs |
어쨋든 이문제의 핵심은 스프레드 문법을 사용해서 배열안에 있는 최소값을 구하고 반복문을 통해서 최소값과 일치하지 않는 값들을 배열에 담아서 반환하면 됩니다! 근데 다른 사람들이 푼 풀이를 보니까 살짝 박탈감이 느껴진다..... 배울점이 너무 많다......ㄷㄷ
728x90
반응형
'프로그래밍 > 코드 문제 풀이' 카테고리의 다른 글
프로그래머스 1단계 - 정수 내림차순으로 배치하기 (0) | 2021.07.01 |
---|---|
프로그래머스 1단계 - 수박수박수박수박수박수? (0) | 2021.06.30 |
프로그래머스 1단계 - 문자열을 정수로 바꾸기 (0) | 2021.06.28 |
프로그래머스 1단계 - 서울에서 김서방 찾기 (0) | 2021.06.27 |
프로그래머스 1단계 - 같은 숫자는 싫어 (0) | 2021.06.26 |
Comments