Notice
Recent Posts
Recent Comments
Link
«   2024/11   »
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
more
Archives
Today
Total
관리 메뉴

코드와이

[SW Expert Academy] 1263. [S/W 문제해결 응용] 8일차 - 사람 네트워크2 본문

SW_Expert

[SW Expert Academy] 1263. [S/W 문제해결 응용] 8일차 - 사람 네트워크2

코드와이 2021. 3. 25. 17:23

 

Floyd

문제링크

swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV18P2B6Iu8CFAZN

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

 

이유를 모르겠지만,

3중 for문에서 'if(i == k) continue;', 'if(j == k || i == j) continue' 라는 조건문을 지우면 실행시간이 절반으로 준다.

package D6;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
 
public class 사람_네트워크2 {
 
    public static void main(String[] args) throws NumberFormatException, IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st;
        StringBuilder sb = new StringBuilder();
         
        int T = Integer.parseInt(br.readLine());
         
        for(int tc = 1 ; tc <= T ; tc++) {
            sb.append("#").append(tc).append(" ");
             
            st = new StringTokenizer(br.readLine());
             
            int n = Integer.parseInt(st.nextToken());
             
            int[][] arr = new int[n][n];
             
            for(int i = 0 ; i < n ; i++) {
                for(int j = 0 ; j < n ; j++) {
                    int x = Integer.parseInt(st.nextToken());
                    arr[i][j] = x;
                    arr[i][j] = arr[i][j] == 0? 987654321 : arr[i][j];
                }
            }
             
            for(int k = 0 ; k < n ; k++) {
                for(int i = 0 ; i < n ; i++) {
                    for(int j = 0 ; j < n ; j++) {
                        arr[i][j] = Math.min(arr[i][j], arr[i][k] + arr[k][j]);
                    }
                }
            }
 
            int ans = Integer.MAX_VALUE;
            for(int i = 0 ; i < n ; i++) {
                int sum = 0;
                boolean flag = true;
                for(int j = 0 ; j < n ; j++) {
                    sum += arr[i][j];
                    if(ans < sum) {
                    	flag = false;
                    	break;
                    }
                }
                if(flag) ans = Math.min(ans, sum);
            }
            sb.append(ans).append("\n");
        }
        sb.setLength(sb.length()-1);
        System.out.println(sb);
    }
}