인프런 커뮤니티 질문&답변
풀이 질문입니다!
해결된 질문
작성
·
193
0
function solution(arr){
let answer=arr;
for (let i = 1; i < arr.length; i++) {
let tmp = i;
for (let j = i-1; j >= 0; j--) {
if (arr[tmp] < arr[j]) {
[arr[j], arr[tmp]] = [arr[tmp], arr[j]];
tmp--;
}
}
}
return answer;
}
let arr=[11, 7, 5, 6, 10, 9];
console.log(solution(arr));
저는 인덱스 값을 tmp 넣어서 풀어보았는데 이렇게 풀어도 괜찮을까요?
퀴즈
66%나 틀려요. 한번 도전해보세요!
선택 정렬 알고리즘의 핵심 과정은 무엇일까요?
인접한 두 요소를 비교하여 순서가 맞지 않으면 교환합니다.
정렬되지 않은 부분에서 가장 작은 값을 찾아 정렬된 부분의 올바른 위치로 옮깁니다.
배열을 반으로 나누고 각 부분을 재귀적으로 정렬한 후 병합합니다.
하나의 요소를 정렬된 하위 배열의 올바른 위치에 삽입합니다.





