#include using namespace std; #define ALL(x) begin(x),end(x) #define rep(i,n) for(int i=0;i<(n);i++) #define debug(v) cout<<#v<<":";for(auto x:v){cout<bool chmax(T &a,const T &b){if(abool chmin(T &a,const T &b){if(b ostream &operator<<(ostream &os,const vector&v){ for(int i=0;i<(int)v.size();i++) os< istream &operator>>(istream &is,vector&v){ for(T &x:v)is>>x; return is; } signed main(){ int n,m;cin>>n>>m; vector> cost(n,vector(n,0)); rep(_,m){ int i,j,c;cin>>i>>j>>c;i--,j--; cost[i][j]=c; } ll dp[n][n][2]; rep(i,n)rep(j,n)rep(k,2)dp[i][j][k]=LINF; dp[0][0][0]=0; using Q=tuple; priority_queue,greater> que; que.emplace(0,0,0,0); while(!que.empty()){ auto [s,i,j,k]=que.top(); que.pop(); rep(l,4){ int ni=i+dx[l],nj=j+dy[l]; if(not (0<=ni and ni