일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- a && b
- Math.min
- 자바스크립트의 탄생배경
- 구문과 의미
- for문
- 자바스크립트
- Ajax란?
- async-await
- JavaScript
- 소름돋는 알고리즘
- .split()
- !x.includes()
- 자바스크립트의 특징
- 자바스크립트와 ECMAScript
- array.reduce()
- 소오름~
- 프로그래머스
- .map()
- 삼항연산자
- for반복문
- 프로그래머스 공원 산책
- 알고리즘
- 행렬...
- 가우스의 공식
- 프로그래밍이란
- 어려운데ㅠㅠ
- arr.push()
- Promise.all()
- ES6 브라우저 지원 현황
- 배열 최솟값
Archives
- Today
- Total
Ming's develop story
알고리즘 - 정수 내림차순으로 배치하기 (21.11.13) 본문
- 정수 내림차순으로 배치하기
문제 설명
함수 solution은 정수 n을 매개변수로 입력받습니다. n의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n이 118372면 873211을 리턴하면 됩니다.
제한 조건- n은 1이상 8000000000 이하인 자연수입니다.
n return
118372 | 873211 |
내 풀이

일단 값을 반환할 answer 변수를 선언해준다.
n을 문자열로 변환시켜 준 뒤에 split을 사용해 배열로 각각 분리시켜준다.
for문을 돌려 각각의 요소를 빈 rArr로 push해주고 반복문이 끝난뒤에 sort()를 통해 내림차순을 해주었다.
마지막으로 join()을 통해 각 요소들을 이어 붙여주며 parseInt()를 사용해 정수로 바꾸어 answer에 할당 해주었다.
한줄로 줄이면 return (n+"").split('').sort((a,b)=>b-a).join('')*1; 이렇게도 짤수 있다....(다른 사람의 풀이)
다른 사람의 풀이

빈 배열 nums를 선언하고 do while문을 통해 n이 0보다 클경우에 10으로 나누며 나머지를 nums에 push 해준다.
그리고 Math.floor()를 사용해 각 자리수의 숫자를 다 반복할수 있도록 하였다.
마지막으로 sort()를 통해 내림차순으로 정렬하고 join('')으로 각 요소를 이어 붙이고 *1을 하여 문자열을 다시 숫자로 반환해 주었다.
'스파르타코딩클럽 - 항해99 > 항해99 Chapter2 - 알고리즘 기초' 카테고리의 다른 글
알고리즘 - 하샤드 수 (21.11.13) (0) | 2021.11.13 |
---|---|
알고리즘 - 정수 제곱근 판별 (21.11.13) (0) | 2021.11.13 |
알고리즘 - 자릿수 더하기 (21.11.12) (0) | 2021.11.12 |
알고리즘 - 이상한 문자 만들기 (21.11.12) (0) | 2021.11.12 |
알고리즘 - 부족한 금액 계산하기 (21.11.12) (0) | 2021.11.12 |