#include <stdio.h>

void DFS(int src,int mat[V][V],int *visited,int V ){
    printf("%d ",src);
    visited[src] = 1;
    for(int i=0;i<V;i++){
        if(mat[src][i] != 0 && visited[i] == 0){
            DFS(i, mat,visited,V);
        }
    }
}

int main(){
    int V,E,r,c,i,u,v,w,src;
    scanf("%d",&V);
    if(V<0){
        printf("Invalid input");
        return 0;
    }
    scanf("%d",&E);
    int mat[V][V],visited[V];
    
    for(r=0;r<V;r++){
        for(c=0;c<V;c++){
           mat[r][c] = 0; 
        }
    }
    for(i=0;i<=E;i++){
        scanf("%d %d %d",&u,&v,&w);
        mat[u][v] = w;
    }
    scanf("%d",&src);
    DFS(src,mat,visited,V);
   
    return 0;
    
}