일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- spring mongodb
- ipfs singletone
- kotiln functional interface
- kotiln const
- spring mongoTemplate
- mongodb lookup
- 백준 특정한 최단 경로
- 전략 패턴이란
- 백준 1504 java
- javav 1676
- 안정해시
- 자바 백준 팩토리얼 개수
- 백준 2252 줄세우기
- java 팩토리얼 개수
- 익명 객체 @transactional
- rabbitmq 싱글톤
- java 백준 1509
- java 1238
- Java Call By Refernce
- Spring ipfs
- 자바 1676
- 백준 연결요소 자바
- kotiln const val
- java 1509
- nodejs rabbitmq
- java 파티
- go
- spring mongoTemplate switch
- spring mongodb switch
- ipfs bean
Archives
- Today
- Total
공부 흔적남기기
[JAVA] 백준 택배 1719 본문
728x90
반응형
각 집하장들이 있고 하나의 집하장에서 또다른 집하장까지의 최소 거리를 구하되 해당 집하장으로 가기위해서 처음 들려야하는 집하장을 구하는 문제이다.
즉 집하장 1에서 집하장 5로 가기위해서는 5라는 비용이 들고 해당 위치로 가기 위해서는 집하장 2를 먼저 가야한다.
먼저 해당 거리까지의 최소 비용을 구한 후 이동할 때 map라는 공간에 어디서 출발했는지를 저장해 놓고 뒤로 돌면서 찾는 방식으로 해결하였다.
// Online Java Compiler
// Use this editor to write, compile and run your Java code online
import java.util.*;
import java.io.*;
class Main {
static class Node{
int v;
int w;
int before;
Node(int v, int w, int before){
this.v =v;
this.w = w;
this.before = before;
}
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
String[] input =br.readLine().split(" ");
int n = Integer.parseInt(input[0]);
int m = Integer.parseInt(input[1]);
ArrayList<ArrayList<Node>> edge = new ArrayList<>();
for(int i =0; i<=n; i++){
edge.add(new ArrayList<Node>());
}
int[][] map = new int[n+1][n+1];
for(int i =0; i<m; i++){
input = br.readLine().split(" ");
int a = Integer.parseInt(input[0]);
int b = Integer.parseInt(input[1]);
int w = Integer.parseInt(input[2]);
edge.get(a).add(new Node(b, w,0));
edge.get(b).add(new Node(a, w,0));
}
for(int i =1; i<=n; i++){
PriorityQueue<Node> pq = new PriorityQueue<>((o1, o2) -> o1.w-o2.w);
int[] dist = new int[n+1];
Arrays.fill(dist, Integer.MAX_VALUE);
pq.offer(new Node(i, 0, 0));
dist[i] = 0;
while(!pq.isEmpty()){
Node node = pq.poll();
int v= node.v;
int w = node.w;
int b = node.before;
if(w > dist[v]) continue;
for(Node no: edge.get(v)){
int t = no.v;
int tw = no.w + w;
int before = v;
if(tw < dist[t]){
dist[t] =tw;
if(map[i][v] ==0){
map[i][t] = t;
}else{
;
while(map[i][before] != before){
before = map[i][before];
}
map[i][t] =before;
}
pq.offer(new Node(t, tw, v));
}
}
}
}
for(int i =1; i<=n; i++){
for(int j =1; j<=n; j++){
if(i == j){
bw.write("- ");
}else{
bw.write(map[i][j] + " ");
}
}
bw.write("\n");
}
bw.flush();
bw.close();
br.close();
}
}
728x90
반응형
'코테 > 백준' 카테고리의 다른 글
[JAVA] 백준 숫자 정사각형 1051 (0) | 2025.03.31 |
---|---|
[JAVA] 백준 가장 큰 정사각형 1915 (0) | 2025.03.30 |
[JAVA] 백준 1509 팰린드롬 분할 (0) | 2025.03.14 |
[JAVA] 파티 1238 (0) | 2025.03.06 |
[JAVA] 백준 특정한 최단 경로 1504 (0) | 2024.12.01 |