티스토리 뷰

알고리즘/코딩테스트 공부

7-1 선택정렬

YG - 96년생 , 강아지 있음, 개발자 희망 2022. 3. 1. 21:02

문제

N개이 숫자가 입력되면 오름차순으로 정렬하여 출력하는 프로그램을 작성하세요. 정렬하는 방법은 선택 정렬입니다.

풀이

function solution(arr) {
  let answer = arr;
  for (let i = 0; i < arr.length; i++) {
    let idx = i;
    console.log(idx);
    for (let j = i + 1; j < arr.length; j++) {
      console.log(arr[j], arr[idx]);
      if (arr[j] < arr[idx]) idx = j;
    }
    [arr[i], arr[idx]] = [arr[idx], arr[i]];
  }
  return answer;
}

let arr = [13, 5, 11, 7, 23, 15];
console.log(solution(arr));

idx를 만들어 arr [j]와 arr [idx]를 비교하여 arr [j] 보다 작은 값이 나온다면 idx를 더 작은 값이 나온 j로 바꾸고 

 

새롭게 업데이트된 자바스크립트 문법으로 순서를 바꿀 수 있다.

 

예를 들어

 

[arr[1], arr[3]] = [arr[3], arr[1]];

 일 경우 arr의 [1]번째 , [3] 번째 값을 [3]번 , [1] 번으로 배열 안의 순서를 바꾼다는 뜻이다.

'알고리즘 > 코딩테스트 공부' 카테고리의 다른 글

8-2. 이진수 출력(재귀)  (0) 2022.03.24
7-2 버블정렬  (0) 2022.03.03
6-7 교육과정 설계 (큐)  (0) 2021.12.10
6-6 공주 구하기(큐)  (0) 2021.12.10
6-5 쇠막대기 (스택)  (0) 2021.12.10
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/12   »
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
글 보관함