#include<stdio.h>
#include<limits.h>

#define INF 1000000000

int main(){
    int n;
    if(scanf("%d", &n) != 1){
        printf("Invalid input");
        return 0;
    }
    
    if(n<0){
        printf("Invalid input");
        return 0;
    }
    
   
  
    
    int cost[105][105];
    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            if(scanf("%d", &cost[i][j]) != 1){
                printf("Invalid input");
                return 0;
            }
            
            
        }
    }
    
    int s;
    if(scanf("%d",&s) != 1){
        printf("Invalid input");
        return 0;
    }
    
    if(s<0 || s >= n){
        printf("Invalid input");
        return 0;
    }
    
   int dist[105], visited[105]={0};
   
    for(int i=0;i<n;i++) dist[i]=INF;
    dist[s]=0;
    
    for(int k=0;k<n-1;k++){
        int u=-1, min=INF;
        for(int i=0;i<n;i++){
            if(!visited[i] && dist[i]<min){
                min=dist[i];
                u=i;
            }
        }
        
        if(u==-1) break;
        visited[u]=1;
        
        for(int v=0;v<n;v++){
            if(!visited[v] && cost[u][v) > 0 && dist[u]+cost[u][v] < dist[v]) {
                dist[v]=dist[u] + cost[u][v];
                
            }
        }
    }
    
    for(int i=0;i<n;i++){
        if(dist[i]==INF) 
        printf("-1");
        else 
        printf("%d", dist[i]);
        if(i != n-1)
        printf(" ");
    }
    return 0;
}