[TIL] 다익스트라 알고리즘

Captainjack·2022년 1월 24일
0

TIL

목록 보기
136/260

프로그래머스 level2 배달 문제


 function getSmallIndex(N, visit_Check, distance) {
  let INF = 500000;
  let min = INF;
  let index = 0;
  // console.log(visit_Check);
  for(let i = 0; i < N; i++) {
    if(distance[i] < min && !visit_Check[i]) {
      min = distance[i];
      index = i;
    }
  }
  return index;
}

function solution(N, road, K) {
  let arr = [];
  let INF = 500000;
  let visit_Check = [];
  let distance = [];
  let start = 0;
  
  for(let i = 0; i <= N; i++) {
    // arr[i].push(i);
    arr.push(Array(Number(N) + 1).fill(INF));
  }


  visit_Check[start] = true;

  for(let i = 0; i < N; i++) {
    arr[i][i] = 0;
  }

  for(let i = 0; i < road.length; i++) {
    if(arr[road[i][0]][road[i][1]] > road[i][2]) {
      arr[road[i][0]][road[i][1]] = road[i][2];
      arr[road[i][1]][road[i][0]] = road[i][2];
    }
    
    // arr[road[i][0] - 1][road[i][1] - 1] = road[i][2] - 1;
    // arr[road[i][1] - 1][road[i][0] - 1] = road[i][2] - 1;

    // console.log(arr[road[i][0]][road[0][1]]);
  }
  // for (let i = 0; i < road.length; i++) {
  //   if(obj[i] =
	// }
  arr.shift();
  // console.log(arr);
  // console.log(arr.length)

  for(let i = 0; i < N; i++) {
    arr[i].shift();
  }

  console.log(arr);


  for(let i = 0; i < N; i++) {
    distance[i] = arr[start][i];
  }


  console.log(distance);

  for(let i = 0; i < N - 2; i++) {
    let current = getSmallIndex(N, visit_Check, distance);
    visit_Check[current] = true;
    for(let j = 0; j < N; j++) {
      if(!visit_Check[j]) {
        if(distance[current] + arr[current][j] < distance[j]) {
          distance[j] = distance[current] + arr[current][j];
        }
      }
    }
  }
  console.log(distance);
  let count = 0;
  for(let i = 0; i < distance.length; i++) {
    if(distance[i] <= K) {
      count++;
    }
  }
  console.log(count);
  return count;
}

// 낚임 1. 마을 간의 간선은 하나가 아닐 수도 있다
// 낚임 2. 간선 최대 길이는 50,000이다.

맵핑 부분 엉망이라 수정했음 😉


참고 및 출처

https://m.blog.naver.com/ndb796/221234424646

profile
til' CTF WIN

0개의 댓글