#include <string>
#include <vector>
#include <algorithm>
#include <numeric>
#include <set>
#include <map>
#include <queue>
#include<stack>
#include<bitset>
#include <iostream>
#include <sstream>
#include <cstdio>
#include <cmath>
#include <ctime>
#include <cstring>
#include <cctype>
#include <cassert>
#include <limits>
#include <functional>
#include<unordered_map>
#define rep(i,n) for(int (i)=0;(i)<(int)(n);++(i))
#define reu(i,l,u) for(int (i)=(int)(l);(i)<(int)(u);++(i))
#define aut(r,v) for(auto r:v)
#define each(it,o) for(aut(it, (o).begin()); it != (o).end(); ++ it)
#define all(o) (o).begin(), (o).end()
#define pb(x) push_back(x)
#define pc() pop_back()
#define ull unsigned long long
#define mp(x,y) make_pair((x),(y))
#define mset(m,v) memset(m,v,sizeof(m))
#define INF 0x3f3f3f3f
#define INFL 0x3f3f3f3f3f3f3f3fLL
using namespace std;
#define endl '\n'
#define st stack<int>
#define vl vector<long long>
#define vi vector<int>
#define vb vector<bool>
#define vc vector<char>
#define pii pair<int,int>
#define vpii vector<pii>
#define vvi vector<vi>
#define vs vector<string>
#define mod 1000000007
#define un unordered_map<int,int>
#define mii map<int,int>
#define Sort(a) sort(all(a))
#define ED(a) Sort(a), a.erase(unique(all(a)), a.end())//removing all duplicates
#define max3(a, b, c) max(a, max(b, c))
#define min3(a, b, c) min(a, min(b, c))
#define Max(a) *max_element(all(a))
#define Min(a) *min_element(all(a))
#define MaxP(a) max_element(all(a)) - a.begin()
#define MinP(a) min_element(all(a)) - a.begin()
#define allUpper(a) transform(all(a), a.begin(), :: toupper)
#define allLower(a) transform(all(a), a.begin(), :: tolower)
#define rev(a) reverse(all(a))
#define ub(v,k) upper_bound(all(v), k) - v.begin()
#define lb(v,k) lower_bound(all(v), k) - v.begin()
#define adv(a,n) advance(auto it:a,n)
#define RSort(a) sort(a.rbegin(),a.rend()) //decending order
#define cnt(v,a) count(all(v),a)
#define bs(v,a) binary_search(all(v),a)
#define mmax(v) *max_element(all(v))
#define mmin(v) *min_element(all(v))
#define popcount(mask) __builtin_popcount(mask) // count set bit
#define popcountLL(mask) __builtin_popcountll(mask) // for long long
#define X real() // useful for working with #include <complex> for computational geometry
#define Y imag()
#define ll long long
#define ss second
#define ff first
#define trace1(x) cerr << #x << ": " << x << endl;
#define trace2(x, y) cerr << #x << ": " << x << " | " << #y << ": " << y << endl;
#define trace3(x, y, z) cerr << #x << ": " << x << " | " << #y << ": " << y << " | " << #z << ": " << z << endl;
#define trace4(a, b, c, d) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << endl;
#define trace5(a, b, c, d, e) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << " | " << #e << ": " << e << endl;
#define trace6(a, b, c, d, e, f) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << " | " << #e << ": " << e << " | " << #f << ": " << f << endl;
template <typename T> T gcd(T a, T b) { while (b) b ^= a ^= b ^= a %= b; return a; }
template <typename T> T setbit(T mask, T pos) { return mask |= (1 << pos); }
template <typename T> T resetbit(T mask, T pos) { return mask &= ~(1 << pos); }
template <typename T> T togglebit(T mask, T pos) { return mask ^= (1 << pos); }
template <typename T> T checkbit(T mask, T pos) { return (bool)(mask & (1 << pos)); }
template <typename T> T lcm(T a, T b) { return (a / gcd(a, b)) * b; }
template <typename T> T modu(T a, T b) { return (a < b ? a : a % b); }
template<typename T> T mod_neg(T a, T b) { a = mod(a, b); if (a < 0) { a += b; } return a; }
template <typename T>T expo(T e, T n) { T x = 1, p = e; while (n) { if (n & 1)x = x * p; p = p * p; n >>= 1; } return x; }
template<typename T> T mod_inverse(T a, T n) { T x, y; T d = extended_euclid(a, n, x, y); return (d > 1 ? -1 : mod_neg(x, n)); }
template <typename T>T power(T e, T n, T m) { T x = 1, p = e; while (n) { if (n & 1)x = mod(x * p, m); p = mod(p * p, m); n >>= 1; } return x; }
template <typename T>T powerL(T e, T n, T m) { T x = 1, p = e; while (n) { if (n & 1)x = mulmod(x, p, m); p = mulmod(p, p, m); n >>= 1; } return x; }
bool Pow2(int n) {
return n && (!(n & (n - 1)));
}
void printc(vc& result) {
aut(r, result) cout << r << " ";
cout << endl;
}
void printl(vl& result) {
aut(r, result) cout << r << " ";
cout << endl;
}
void print(vi& result) {
aut(r, result) cout << r << " ";
cout << endl;
}
long long binpow(long long a, long long b) {
long long res = 1;
while (b > 0) {
if (b & 1)
res = res * a;
a = a * a;
b >>= 1;
}
return res;
}
/*ll modInv(ll a) { return power(a, mod - 2) % mod; }
ll fact[1], inv[1];
void factorial(ll n) {
fact[0] = 1;
for (ll i = 1; i <= n; i++) {
fact[i] = fact[i - 1] * i;
fact[i] %= mod;
}
}
void InvFactorial(ll n) {
inv[0] = 1;
for (ll i = 1; i <= n; i++)
inv[i] = modInv(fact[i]);
}
ll ncr(ll n, ll r) {
if (n < r || n < 0 || r < 0)
return 0;
ll b = inv[n - r];
ll c = inv[r];
ll a = fact[n] * b;
a %= mod;
a *= c;
a %= mod;
return a;
}*/
//ifstream cin("b_read_on.txt"); ofstream cout("output3.txt");
//Use (<<) for multiplication
//Use (>>) for division
//ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL);cout<<fixed;cerr.tie(NULL);
// find_by_order -> value at index
// order_of_key -> index of value
// while using (1<<i) use ((ll)1<<(ll)i)
// in Floyd-Warshall Algo, k is outer loop
// If an element was not initially in map and if asked mp[a],the element gets inserted
// a%=mod take a lot of time... try to use it minimum and use memset as it reduces a lot of time usage...use if(a>=mod) a%=mod
//cout<<(double) can be harmful , always use printf(%.9llf)...take scanf("%lf",&p[i][j]) as input , not llf;
//use s.erase(it++) for erasing iterator and then moving to the next one
//never use adj.resize(n) as value is persistent, always erase
//use __builtin_popcountll() for ll
// no of prime numbers in range : (70,19) , (1000,168) , (100000,1229) , (sqrt(10^9),3409) ;
//always check the use of segment tree using bottom-up dp
vector<pair<int, int>> adj[100001];
vb vis(100001);
vi dis(100001,INF);
vi par(100001, -1);
void disktraw(int s,int n) {
dis[s] = 0;
priority_queue<pair<int, int>> pq;
pq.push({ 0,s });
while (!pq.empty()) {
int a = pq.top().ss;
pq.pop();
if (vis[a]) continue;
vis[a] = true;
for (auto it : adj[a]) {
int b = it.ff;
int w = it.ss;
if (dis[a] + w < dis[b]) {
par[b] = a;
dis[b] = dis[a] + w;
pq.push({ -dis[b],b });
}
}
}
if (vis[n] == false) cout << -1 << endl;
else {
vi path;
for (int i = n; i != -1; i = par[i]) {
path.pb(i);
}
reverse(all(path));
print(path);
}
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
int test;
test = 1;
// cin >> test;
while (test--) {
int n, m;
cin >> n >> m;
vector<tuple<int, int, int>> edges;
while (m--) {
int a, b, w;
cin >> a >> b >> w;
adj[a].push_back({ b,w });
adj[b].push_back({ a,w });
}
disktraw(1,n);
}
}
I2luY2x1ZGUgPHN0cmluZz4KI2luY2x1ZGUgPHZlY3Rvcj4KI2luY2x1ZGUgPGFsZ29yaXRobT4KI2luY2x1ZGUgPG51bWVyaWM+CiNpbmNsdWRlIDxzZXQ+CiNpbmNsdWRlIDxtYXA+CiNpbmNsdWRlIDxxdWV1ZT4KCiNpbmNsdWRlPHN0YWNrPgojaW5jbHVkZTxiaXRzZXQ+CiNpbmNsdWRlIDxpb3N0cmVhbT4KI2luY2x1ZGUgPHNzdHJlYW0+CiNpbmNsdWRlIDxjc3RkaW8+CiNpbmNsdWRlIDxjbWF0aD4KI2luY2x1ZGUgPGN0aW1lPgojaW5jbHVkZSA8Y3N0cmluZz4KI2luY2x1ZGUgPGNjdHlwZT4KI2luY2x1ZGUgPGNhc3NlcnQ+CiNpbmNsdWRlIDxsaW1pdHM+CiNpbmNsdWRlIDxmdW5jdGlvbmFsPgojaW5jbHVkZTx1bm9yZGVyZWRfbWFwPgoKI2RlZmluZSByZXAoaSxuKSBmb3IoaW50IChpKT0wOyhpKTwoaW50KShuKTsrKyhpKSkKCiNkZWZpbmUgcmV1KGksbCx1KSBmb3IoaW50IChpKT0oaW50KShsKTsoaSk8KGludCkodSk7KysoaSkpCiNkZWZpbmUgYXV0KHIsdikgZm9yKGF1dG8gcjp2KQoKI2RlZmluZSBlYWNoKGl0LG8pIGZvcihhdXQoaXQsIChvKS5iZWdpbigpKTsgaXQgIT0gKG8pLmVuZCgpOyArKyBpdCkKI2RlZmluZSBhbGwobykgKG8pLmJlZ2luKCksIChvKS5lbmQoKQojZGVmaW5lIHBiKHgpIHB1c2hfYmFjayh4KQojZGVmaW5lIHBjKCkgIHBvcF9iYWNrKCkKCiNkZWZpbmUgdWxsIHVuc2lnbmVkIGxvbmcgbG9uZwojZGVmaW5lIG1wKHgseSkgbWFrZV9wYWlyKCh4KSwoeSkpCiNkZWZpbmUgbXNldChtLHYpIG1lbXNldChtLHYsc2l6ZW9mKG0pKQoKI2RlZmluZSBJTkYgMHgzZjNmM2YzZgojZGVmaW5lIElORkwgMHgzZjNmM2YzZjNmM2YzZjNmTEwKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKI2RlZmluZSBlbmRsICdcbicKCiNkZWZpbmUgc3Qgc3RhY2s8aW50PgoKCgojZGVmaW5lIHZsIHZlY3Rvcjxsb25nIGxvbmc+CiNkZWZpbmUgdmkgdmVjdG9yPGludD4KI2RlZmluZSB2YiB2ZWN0b3I8Ym9vbD4KI2RlZmluZSB2YyB2ZWN0b3I8Y2hhcj4KI2RlZmluZSBwaWkgcGFpcjxpbnQsaW50PgojZGVmaW5lIHZwaWkgdmVjdG9yPHBpaT4KI2RlZmluZSB2dmkgdmVjdG9yPHZpPgojZGVmaW5lIHZzIHZlY3RvcjxzdHJpbmc+CgojZGVmaW5lIG1vZCAxMDAwMDAwMDA3CgojZGVmaW5lIHVuICB1bm9yZGVyZWRfbWFwPGludCxpbnQ+CiNkZWZpbmUgbWlpIG1hcDxpbnQsaW50PgoKI2RlZmluZSBTb3J0KGEpIHNvcnQoYWxsKGEpKQojZGVmaW5lIEVEKGEpIFNvcnQoYSksIGEuZXJhc2UodW5pcXVlKGFsbChhKSksIGEuZW5kKCkpLy9yZW1vdmluZyBhbGwgZHVwbGljYXRlcwoKI2RlZmluZSBtYXgzKGEsIGIsIGMpICAgbWF4KGEsIG1heChiLCBjKSkKI2RlZmluZSBtaW4zKGEsIGIsIGMpICAgbWluKGEsIG1pbihiLCBjKSkKI2RlZmluZSBNYXgoYSkgICAgICAgKm1heF9lbGVtZW50KGFsbChhKSkKI2RlZmluZSBNaW4oYSkgICAgICAgKm1pbl9lbGVtZW50KGFsbChhKSkKI2RlZmluZSBNYXhQKGEpICAgICAgIG1heF9lbGVtZW50KGFsbChhKSkgLSBhLmJlZ2luKCkKI2RlZmluZSBNaW5QKGEpICAgICAgICBtaW5fZWxlbWVudChhbGwoYSkpIC0gYS5iZWdpbigpCgojZGVmaW5lIGFsbFVwcGVyKGEpICAgICB0cmFuc2Zvcm0oYWxsKGEpLCBhLmJlZ2luKCksIDo6IHRvdXBwZXIpCiNkZWZpbmUgYWxsTG93ZXIoYSkgICAgIHRyYW5zZm9ybShhbGwoYSksIGEuYmVnaW4oKSwgOjogdG9sb3dlcikKCiNkZWZpbmUgcmV2KGEpICAgICAgICAgIHJldmVyc2UoYWxsKGEpKQojZGVmaW5lIHViKHYsaykgICAgICAgICAgdXBwZXJfYm91bmQoYWxsKHYpLCBrKSAtIHYuYmVnaW4oKQojZGVmaW5lIGxiKHYsaykgICAgICAgICAgbG93ZXJfYm91bmQoYWxsKHYpLCBrKSAtIHYuYmVnaW4oKQojZGVmaW5lIGFkdihhLG4pICAgICAgICBhZHZhbmNlKGF1dG8gaXQ6YSxuKQojZGVmaW5lIFJTb3J0KGEpICAgICAgICAgc29ydChhLnJiZWdpbigpLGEucmVuZCgpKSAvL2RlY2VuZGluZyBvcmRlcgojZGVmaW5lIGNudCh2LGEpICAgICAgICAgICAgIGNvdW50KGFsbCh2KSxhKQojZGVmaW5lIGJzKHYsYSkgICAgICAgICAgIGJpbmFyeV9zZWFyY2goYWxsKHYpLGEpCiNkZWZpbmUgbW1heCh2KSAgICAgICAgICAgKm1heF9lbGVtZW50KGFsbCh2KSkKI2RlZmluZSBtbWluKHYpICAgICAgICAgICAqbWluX2VsZW1lbnQoYWxsKHYpKQojZGVmaW5lIHBvcGNvdW50KG1hc2spICAgICAgICAgICAgICAgICAgICAgICBfX2J1aWx0aW5fcG9wY291bnQobWFzaykgLy8gY291bnQgc2V0IGJpdAojZGVmaW5lIHBvcGNvdW50TEwobWFzaykgICAgICAgICAgICAgICAgICAgICBfX2J1aWx0aW5fcG9wY291bnRsbChtYXNrKSAvLyBmb3IgbG9uZyBsb25nCiNkZWZpbmUgWCByZWFsKCkgLy8gdXNlZnVsIGZvciB3b3JraW5nIHdpdGggI2luY2x1ZGUgPGNvbXBsZXg+IGZvciBjb21wdXRhdGlvbmFsIGdlb21ldHJ5CiNkZWZpbmUgWSBpbWFnKCkKI2RlZmluZSBsbCBsb25nIGxvbmcKI2RlZmluZSBzcyBzZWNvbmQKI2RlZmluZSBmZiBmaXJzdAoKI2RlZmluZSB0cmFjZTEoeCkgICAgICAgICAgICAgICAgICAgICAgICAgICBjZXJyIDw8ICN4IDw8ICI6ICIgPDwgeCA8PCBlbmRsOwojZGVmaW5lIHRyYWNlMih4LCB5KSAgICAgICAgICAgICAgICAgICAgICAgIGNlcnIgPDwgI3ggPDwgIjogIiA8PCB4IDw8ICIgfCAiIDw8ICN5IDw8ICI6ICIgPDwgeSA8PCBlbmRsOwojZGVmaW5lIHRyYWNlMyh4LCB5LCB6KSAgICAgICAgICAgICAgICAgICAgIGNlcnIgPDwgI3ggPDwgIjogIiA8PCB4IDw8ICIgfCAiIDw8ICN5IDw8ICI6ICIgPDwgeSA8PCAiIHwgIiA8PCAjeiA8PCAiOiAiIDw8IHogPDwgZW5kbDsKI2RlZmluZSB0cmFjZTQoYSwgYiwgYywgZCkgICAgICAgICAgICAgICAgICBjZXJyIDw8ICNhIDw8ICI6ICIgPDwgYSA8PCAiIHwgIiA8PCAjYiA8PCAiOiAiIDw8IGIgPDwgIiB8ICIgPDwgI2MgPDwgIjogIiA8PCBjIDw8ICIgfCAiIDw8ICNkIDw8ICI6ICIgPDwgZCA8PCBlbmRsOwojZGVmaW5lIHRyYWNlNShhLCBiLCBjLCBkLCBlKSAgICAgICAgICAgICAgIGNlcnIgPDwgI2EgPDwgIjogIiA8PCBhIDw8ICIgfCAiIDw8ICNiIDw8ICI6ICIgPDwgYiA8PCAiIHwgIiA8PCAjYyA8PCAiOiAiIDw8IGMgPDwgIiB8ICIgPDwgI2QgPDwgIjogIiA8PCBkIDw8ICIgfCAiIDw8ICNlIDw8ICI6ICIgPDwgZSA8PCBlbmRsOwojZGVmaW5lIHRyYWNlNihhLCBiLCBjLCBkLCBlLCBmKSAgICAgICAgICAgIGNlcnIgPDwgI2EgPDwgIjogIiA8PCBhIDw8ICIgfCAiIDw8ICNiIDw8ICI6ICIgPDwgYiA8PCAiIHwgIiA8PCAjYyA8PCAiOiAiIDw8IGMgPDwgIiB8ICIgPDwgI2QgPDwgIjogIiA8PCBkIDw8ICIgfCAiIDw8ICNlIDw8ICI6ICIgPDwgZSA8PCAiIHwgIiA8PCAjZiA8PCAiOiAiIDw8IGYgPDwgZW5kbDsKCnRlbXBsYXRlIDx0eXBlbmFtZSBUPiBUIGdjZChUIGEsIFQgYikgeyB3aGlsZSAoYikgYiBePSBhIF49IGIgXj0gYSAlPSBiOyByZXR1cm4gYTsgfQp0ZW1wbGF0ZSA8dHlwZW5hbWUgVD4gVCBzZXRiaXQoVCBtYXNrLCBUIHBvcykgeyByZXR1cm4gbWFzayB8PSAoMSA8PCBwb3MpOyB9CnRlbXBsYXRlIDx0eXBlbmFtZSBUPiBUIHJlc2V0Yml0KFQgbWFzaywgVCBwb3MpIHsgcmV0dXJuIG1hc2sgJj0gfigxIDw8IHBvcyk7IH0KdGVtcGxhdGUgPHR5cGVuYW1lIFQ+IFQgdG9nZ2xlYml0KFQgbWFzaywgVCBwb3MpIHsgcmV0dXJuIG1hc2sgXj0gKDEgPDwgcG9zKTsgfQp0ZW1wbGF0ZSA8dHlwZW5hbWUgVD4gVCBjaGVja2JpdChUIG1hc2ssIFQgcG9zKSB7IHJldHVybiAoYm9vbCkobWFzayAmICgxIDw8IHBvcykpOyB9CnRlbXBsYXRlIDx0eXBlbmFtZSBUPiBUIGxjbShUIGEsIFQgYikgeyByZXR1cm4gKGEgLyBnY2QoYSwgYikpICogYjsgfQoKCgp0ZW1wbGF0ZSA8dHlwZW5hbWUgVD4gVCBtb2R1KFQgYSwgVCBiKSB7IHJldHVybiAoYSA8IGIgPyBhIDogYSAlIGIpOyB9CnRlbXBsYXRlPHR5cGVuYW1lIFQ+IFQgbW9kX25lZyhUIGEsIFQgYikgeyBhID0gbW9kKGEsIGIpOyBpZiAoYSA8IDApIHsgYSArPSBiOyB9IHJldHVybiBhOyB9Cgp0ZW1wbGF0ZSA8dHlwZW5hbWUgVD5UIGV4cG8oVCBlLCBUIG4pIHsgVCB4ID0gMSwgcCA9IGU7IHdoaWxlIChuKSB7IGlmIChuICYgMSl4ID0geCAqIHA7IHAgPSBwICogcDsgbiA+Pj0gMTsgfSByZXR1cm4geDsgfQp0ZW1wbGF0ZTx0eXBlbmFtZSBUPiBUIG1vZF9pbnZlcnNlKFQgYSwgVCBuKSB7IFQgeCwgeTsgVCBkID0gZXh0ZW5kZWRfZXVjbGlkKGEsIG4sIHgsIHkpOyByZXR1cm4gKGQgPiAxID8gLTEgOiBtb2RfbmVnKHgsIG4pKTsgfQoKdGVtcGxhdGUgPHR5cGVuYW1lIFQ+VCBwb3dlcihUIGUsIFQgbiwgVCBtKSB7IFQgeCA9IDEsIHAgPSBlOyB3aGlsZSAobikgeyBpZiAobiAmIDEpeCA9IG1vZCh4ICogcCwgbSk7IHAgPSBtb2QocCAqIHAsIG0pOyBuID4+PSAxOyB9IHJldHVybiB4OyB9CnRlbXBsYXRlIDx0eXBlbmFtZSBUPlQgcG93ZXJMKFQgZSwgVCBuLCBUIG0pIHsgVCB4ID0gMSwgcCA9IGU7IHdoaWxlIChuKSB7IGlmIChuICYgMSl4ID0gbXVsbW9kKHgsIHAsIG0pOyBwID0gbXVsbW9kKHAsIHAsIG0pOyBuID4+PSAxOyB9IHJldHVybiB4OyB9Cgpib29sIFBvdzIoaW50IG4pIHsKICAgIHJldHVybiBuICYmICghKG4gJiAobiAtIDEpKSk7Cn0Kdm9pZCBwcmludGModmMmIHJlc3VsdCkgewogICAgYXV0KHIsIHJlc3VsdCkgY291dCA8PCByIDw8ICIgIjsKICAgIGNvdXQgPDwgZW5kbDsKfQp2b2lkIHByaW50bCh2bCYgcmVzdWx0KSB7CiAgICBhdXQociwgcmVzdWx0KSBjb3V0IDw8IHIgPDwgIiAiOwogICAgY291dCA8PCBlbmRsOwp9CnZvaWQgcHJpbnQodmkmIHJlc3VsdCkgewogICAgYXV0KHIsIHJlc3VsdCkgY291dCA8PCByIDw8ICIgIjsKICAgIGNvdXQgPDwgZW5kbDsKfQoKbG9uZyBsb25nIGJpbnBvdyhsb25nIGxvbmcgYSwgbG9uZyBsb25nIGIpIHsKICAgIGxvbmcgbG9uZyByZXMgPSAxOwogICAgd2hpbGUgKGIgPiAwKSB7CiAgICAgICAgaWYgKGIgJiAxKQogICAgICAgICAgICByZXMgPSByZXMgKiBhOwogICAgICAgIGEgPSBhICogYTsKICAgICAgICBiID4+PSAxOwogICAgfQogICAgcmV0dXJuIHJlczsKfQovKmxsIG1vZEludihsbCBhKSB7IHJldHVybiBwb3dlcihhLCBtb2QgLSAyKSAlIG1vZDsgfQpsbCBmYWN0WzFdLCBpbnZbMV07CnZvaWQgZmFjdG9yaWFsKGxsIG4pIHsKICAgIGZhY3RbMF0gPSAxOwogICAgZm9yIChsbCBpID0gMTsgaSA8PSBuOyBpKyspIHsKICAgICAgICBmYWN0W2ldID0gZmFjdFtpIC0gMV0gKiBpOwogICAgICAgIGZhY3RbaV0gJT0gbW9kOwogICAgfQp9CnZvaWQgSW52RmFjdG9yaWFsKGxsIG4pIHsKICAgIGludlswXSA9IDE7CiAgICBmb3IgKGxsIGkgPSAxOyBpIDw9IG47IGkrKykKICAgICAgICBpbnZbaV0gPSBtb2RJbnYoZmFjdFtpXSk7Cn0KbGwgbmNyKGxsIG4sIGxsIHIpIHsKICAgIGlmIChuIDwgciB8fCBuIDwgMCB8fCByIDwgMCkKICAgICAgICByZXR1cm4gMDsKICAgIGxsIGIgPSBpbnZbbiAtIHJdOwogICAgbGwgYyA9IGludltyXTsKICAgIGxsIGEgPSBmYWN0W25dICogYjsKICAgIGEgJT0gbW9kOwogICAgYSAqPSBjOwogICAgYSAlPSBtb2Q7CiAgICByZXR1cm4gYTsKfSovCi8vaWZzdHJlYW0gY2luKCJiX3JlYWRfb24udHh0Iik7IG9mc3RyZWFtIGNvdXQoIm91dHB1dDMudHh0Iik7Ci8vVXNlICg8PCkgZm9yIG11bHRpcGxpY2F0aW9uCi8vVXNlICg+PikgZm9yIGRpdmlzaW9uCi8vaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbyhmYWxzZSk7Y2luLnRpZShOVUxMKTtjb3V0LnRpZShOVUxMKTtjb3V0PDxmaXhlZDtjZXJyLnRpZShOVUxMKTsKLy8gZmluZF9ieV9vcmRlciAtPiB2YWx1ZSBhdCBpbmRleAovLyBvcmRlcl9vZl9rZXkgLT4gaW5kZXggb2YgdmFsdWUKLy8gd2hpbGUgdXNpbmcgKDE8PGkpIHVzZSAoKGxsKTE8PChsbClpKSAKLy8gaW4gRmxveWQtV2Fyc2hhbGwgQWxnbywgayBpcyBvdXRlciBsb29wIAovLyBJZiBhbiBlbGVtZW50IHdhcyBub3QgaW5pdGlhbGx5IGluIG1hcCBhbmQgaWYgYXNrZWQgbXBbYV0sdGhlIGVsZW1lbnQgZ2V0cyBpbnNlcnRlZCAKLy8gYSU9bW9kIHRha2UgYSBsb3Qgb2YgdGltZS4uLiB0cnkgdG8gdXNlIGl0IG1pbmltdW0gYW5kIHVzZSBtZW1zZXQgYXMgaXQgcmVkdWNlcyBhIGxvdCBvZiB0aW1lIHVzYWdlLi4udXNlIGlmKGE+PW1vZCkgYSU9bW9kCi8vY291dDw8KGRvdWJsZSkgY2FuIGJlIGhhcm1mdWwgLCBhbHdheXMgdXNlIHByaW50ZiglLjlsbGYpLi4udGFrZSBzY2FuZigiJWxmIiwmcFtpXVtqXSkgYXMgaW5wdXQgLCBub3QgbGxmOwovL3VzZSBzLmVyYXNlKGl0KyspIGZvciBlcmFzaW5nIGl0ZXJhdG9yIGFuZCB0aGVuIG1vdmluZyB0byB0aGUgbmV4dCBvbmUKLy9uZXZlciB1c2UgYWRqLnJlc2l6ZShuKSBhcyB2YWx1ZSBpcyBwZXJzaXN0ZW50LCBhbHdheXMgZXJhc2UKLy91c2UgX19idWlsdGluX3BvcGNvdW50bGwoKSBmb3IgbGwKLy8gbm8gb2YgcHJpbWUgbnVtYmVycyBpbiByYW5nZSA6ICg3MCwxOSkgLCAoMTAwMCwxNjgpICwgKDEwMDAwMCwxMjI5KSAsIChzcXJ0KDEwXjkpLDM0MDkpIDsKLy9hbHdheXMgY2hlY2sgdGhlIHVzZSBvZiBzZWdtZW50IHRyZWUgdXNpbmcgYm90dG9tLXVwIGRwCnZlY3RvcjxwYWlyPGludCwgaW50Pj4gYWRqWzEwMDAwMV07CnZiIHZpcygxMDAwMDEpOwp2aSBkaXMoMTAwMDAxLElORik7CnZpIHBhcigxMDAwMDEsIC0xKTsKdm9pZCBkaXNrdHJhdyhpbnQgcyxpbnQgbikgewogICAgZGlzW3NdID0gMDsKICAgIHByaW9yaXR5X3F1ZXVlPHBhaXI8aW50LCBpbnQ+PiBwcTsKICAgIHBxLnB1c2goeyAwLHMgfSk7CiAgICB3aGlsZSAoIXBxLmVtcHR5KCkpIHsKICAgICAgICBpbnQgYSA9IHBxLnRvcCgpLnNzOwogICAgICAgIHBxLnBvcCgpOwogICAgICAgIGlmICh2aXNbYV0pIGNvbnRpbnVlOwogICAgICAgIHZpc1thXSA9IHRydWU7CiAgICAgICAgZm9yIChhdXRvIGl0IDogYWRqW2FdKSB7CiAgICAgICAgICAgIGludCBiID0gaXQuZmY7CiAgICAgICAgICAgIGludCB3ID0gaXQuc3M7CiAgICAgICAgICAgIGlmIChkaXNbYV0gKyB3IDwgZGlzW2JdKSB7CiAgICAgICAgICAgICAgICBwYXJbYl0gPSBhOwogICAgICAgICAgICAgICAgZGlzW2JdID0gZGlzW2FdICsgdzsKICAgICAgICAgICAgICAgIHBxLnB1c2goeyAtZGlzW2JdLGIgfSk7CiAgICAgICAgICAgIH0KICAgICAgICB9CgogICAgfQogICAgaWYgKHZpc1tuXSA9PSBmYWxzZSkgY291dCA8PCAtMSA8PCBlbmRsOwogICAgZWxzZSB7CiAgICAgICAgdmkgcGF0aDsKICAgICAgICBmb3IgKGludCBpID0gbjsgaSAhPSAtMTsgaSA9IHBhcltpXSkgewogICAgICAgICAgICBwYXRoLnBiKGkpOwogICAgICAgIH0KICAgICAgICByZXZlcnNlKGFsbChwYXRoKSk7CiAgICAgICAgcHJpbnQocGF0aCk7CgogICAgfQp9CgoKCgoKaW50IG1haW4oKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsKICAgIGNpbi50aWUoTlVMTCk7CiAgICBjb3V0LnRpZShOVUxMKTsKICAgIGludCB0ZXN0OwogICAgdGVzdCA9IDE7CiAgICAvLyBjaW4gPj4gdGVzdDsKICAgIHdoaWxlICh0ZXN0LS0pIHsKICAgICAgICBpbnQgbiwgbTsKICAgICAgICBjaW4gPj4gbiA+PiBtOwogICAgICAgIHZlY3Rvcjx0dXBsZTxpbnQsIGludCwgaW50Pj4gZWRnZXM7CiAgICAgICAgd2hpbGUgKG0tLSkgewogICAgICAgICAgICBpbnQgYSwgYiwgdzsKICAgICAgICAgICAgY2luID4+IGEgPj4gYiA+PiB3OwogICAgICAgICAgICBhZGpbYV0ucHVzaF9iYWNrKHsgYix3IH0pOwogICAgICAgICAgICBhZGpbYl0ucHVzaF9iYWNrKHsgYSx3IH0pOwoKICAgICAgICB9CiAgICAgICAgZGlza3RyYXcoMSxuKTsKICAgIH0KCn0KCgoKCgoKCsKg
Main.java:1: error: illegal character: '#'
#include <string>
^
Main.java:1: error: class, interface, or enum expected
#include <string>
^
Main.java:2: error: illegal character: '#'
#include <vector>
^
Main.java:3: error: illegal character: '#'
#include <algorithm>
^
Main.java:4: error: illegal character: '#'
#include <numeric>
^
Main.java:5: error: illegal character: '#'
#include <set>
^
Main.java:6: error: illegal character: '#'
#include <map>
^
Main.java:7: error: illegal character: '#'
#include <queue>
^
Main.java:9: error: illegal character: '#'
#include<stack>
^
Main.java:10: error: illegal character: '#'
#include<bitset>
^
Main.java:11: error: illegal character: '#'
#include <iostream>
^
Main.java:12: error: illegal character: '#'
#include <sstream>
^
Main.java:13: error: illegal character: '#'
#include <cstdio>
^
Main.java:14: error: illegal character: '#'
#include <cmath>
^
Main.java:15: error: illegal character: '#'
#include <ctime>
^
Main.java:16: error: illegal character: '#'
#include <cstring>
^
Main.java:17: error: illegal character: '#'
#include <cctype>
^
Main.java:18: error: illegal character: '#'
#include <cassert>
^
Main.java:19: error: illegal character: '#'
#include <limits>
^
Main.java:20: error: illegal character: '#'
#include <functional>
^
Main.java:21: error: illegal character: '#'
#include<unordered_map>
^
Main.java:23: error: illegal character: '#'
#define rep(i,n) for(int (i)=0;(i)<(int)(n);++(i))
^
Main.java:23: error: class, interface, or enum expected
#define rep(i,n) for(int (i)=0;(i)<(int)(n);++(i))
^
Main.java:23: error: class, interface, or enum expected
#define rep(i,n) for(int (i)=0;(i)<(int)(n);++(i))
^
Main.java:25: error: illegal character: '#'
#define reu(i,l,u) for(int (i)=(int)(l);(i)<(int)(u);++(i))
^
Main.java:25: error: class, interface, or enum expected
#define reu(i,l,u) for(int (i)=(int)(l);(i)<(int)(u);++(i))
^
Main.java:25: error: class, interface, or enum expected
#define reu(i,l,u) for(int (i)=(int)(l);(i)<(int)(u);++(i))
^
Main.java:26: error: illegal character: '#'
#define aut(r,v) for(auto r:v)
^
Main.java:28: error: illegal character: '#'
#define each(it,o) for(aut(it, (o).begin()); it != (o).end(); ++ it)
^
Main.java:28: error: class, interface, or enum expected
#define each(it,o) for(aut(it, (o).begin()); it != (o).end(); ++ it)
^
Main.java:28: error: class, interface, or enum expected
#define each(it,o) for(aut(it, (o).begin()); it != (o).end(); ++ it)
^
Main.java:29: error: illegal character: '#'
#define all(o) (o).begin(), (o).end()
^
Main.java:30: error: illegal character: '#'
#define pb(x) push_back(x)
^
Main.java:31: error: illegal character: '#'
#define pc() pop_back()
^
Main.java:33: error: illegal character: '#'
#define ull unsigned long long
^
Main.java:34: error: illegal character: '#'
#define mp(x,y) make_pair((x),(y))
^
Main.java:35: error: illegal character: '#'
#define mset(m,v) memset(m,v,sizeof(m))
^
Main.java:37: error: illegal character: '#'
#define INF 0x3f3f3f3f
^
Main.java:38: error: illegal character: '#'
#define INFL 0x3f3f3f3f3f3f3f3fLL
^
Main.java:40: error: illegal character: '#'
#define endl '\n'
^
Main.java:40: error: class, interface, or enum expected
#define endl '\n'
^
Main.java:42: error: illegal character: '#'
#define st stack<int>
^
Main.java:46: error: illegal character: '#'
#define vl vector<long long>
^
Main.java:47: error: illegal character: '#'
#define vi vector<int>
^
Main.java:48: error: illegal character: '#'
#define vb vector<bool>
^
Main.java:49: error: illegal character: '#'
#define vc vector<char>
^
Main.java:50: error: illegal character: '#'
#define pii pair<int,int>
^
Main.java:51: error: illegal character: '#'
#define vpii vector<pii>
^
Main.java:52: error: illegal character: '#'
#define vvi vector<vi>
^
Main.java:53: error: illegal character: '#'
#define vs vector<string>
^
Main.java:55: error: illegal character: '#'
#define mod 1000000007
^
Main.java:57: error: illegal character: '#'
#define un unordered_map<int,int>
^
Main.java:58: error: illegal character: '#'
#define mii map<int,int>
^
Main.java:60: error: illegal character: '#'
#define Sort(a) sort(all(a))
^
Main.java:61: error: illegal character: '#'
#define ED(a) Sort(a), a.erase(unique(all(a)), a.end())//removing all duplicates
^
Main.java:63: error: illegal character: '#'
#define max3(a, b, c) max(a, max(b, c))
^
Main.java:64: error: illegal character: '#'
#define min3(a, b, c) min(a, min(b, c))
^
Main.java:65: error: illegal character: '#'
#define Max(a) *max_element(all(a))
^
Main.java:66: error: illegal character: '#'
#define Min(a) *min_element(all(a))
^
Main.java:67: error: illegal character: '#'
#define MaxP(a) max_element(all(a)) - a.begin()
^
Main.java:68: error: illegal character: '#'
#define MinP(a) min_element(all(a)) - a.begin()
^
Main.java:70: error: illegal character: '#'
#define allUpper(a) transform(all(a), a.begin(), :: toupper)
^
Main.java:71: error: illegal character: '#'
#define allLower(a) transform(all(a), a.begin(), :: tolower)
^
Main.java:73: error: illegal character: '#'
#define rev(a) reverse(all(a))
^
Main.java:74: error: illegal character: '#'
#define ub(v,k) upper_bound(all(v), k) - v.begin()
^
Main.java:75: error: illegal character: '#'
#define lb(v,k) lower_bound(all(v), k) - v.begin()
^
Main.java:76: error: illegal character: '#'
#define adv(a,n) advance(auto it:a,n)
^
Main.java:77: error: illegal character: '#'
#define RSort(a) sort(a.rbegin(),a.rend()) //decending order
^
Main.java:78: error: illegal character: '#'
#define cnt(v,a) count(all(v),a)
^
Main.java:79: error: illegal character: '#'
#define bs(v,a) binary_search(all(v),a)
^
Main.java:80: error: illegal character: '#'
#define mmax(v) *max_element(all(v))
^
Main.java:81: error: illegal character: '#'
#define mmin(v) *min_element(all(v))
^
Main.java:82: error: illegal character: '#'
#define popcount(mask) __builtin_popcount(mask) // count set bit
^
Main.java:83: error: illegal character: '#'
#define popcountLL(mask) __builtin_popcountll(mask) // for long long
^
Main.java:84: error: illegal character: '#'
#define X real() // useful for working with #include <complex> for computational geometry
^
Main.java:85: error: illegal character: '#'
#define Y imag()
^
Main.java:86: error: illegal character: '#'
#define ll long long
^
Main.java:87: error: illegal character: '#'
#define ss second
^
Main.java:88: error: illegal character: '#'
#define ff first
^
Main.java:90: error: illegal character: '#'
#define trace1(x) cerr << #x << ": " << x << endl;
^
Main.java:90: error: illegal character: '#'
#define trace1(x) cerr << #x << ": " << x << endl;
^
Main.java:91: error: illegal character: '#'
#define trace2(x, y) cerr << #x << ": " << x << " | " << #y << ": " << y << endl;
^
Main.java:91: error: class, interface, or enum expected
#define trace2(x, y) cerr << #x << ": " << x << " | " << #y << ": " << y << endl;
^
Main.java:91: error: illegal character: '#'
#define trace2(x, y) cerr << #x << ": " << x << " | " << #y << ": " << y << endl;
^
Main.java:91: error: illegal character: '#'
#define trace2(x, y) cerr << #x << ": " << x << " | " << #y << ": " << y << endl;
^
Main.java:92: error: illegal character: '#'
#define trace3(x, y, z) cerr << #x << ": " << x << " | " << #y << ": " << y << " | " << #z << ": " << z << endl;
^
Main.java:92: error: class, interface, or enum expected
#define trace3(x, y, z) cerr << #x << ": " << x << " | " << #y << ": " << y << " | " << #z << ": " << z << endl;
^
Main.java:92: error: illegal character: '#'
#define trace3(x, y, z) cerr << #x << ": " << x << " | " << #y << ": " << y << " | " << #z << ": " << z << endl;
^
Main.java:92: error: illegal character: '#'
#define trace3(x, y, z) cerr << #x << ": " << x << " | " << #y << ": " << y << " | " << #z << ": " << z << endl;
^
Main.java:92: error: illegal character: '#'
#define trace3(x, y, z) cerr << #x << ": " << x << " | " << #y << ": " << y << " | " << #z << ": " << z << endl;
^
Main.java:93: error: illegal character: '#'
#define trace4(a, b, c, d) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << endl;
^
Main.java:93: error: class, interface, or enum expected
#define trace4(a, b, c, d) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << endl;
^
Main.java:93: error: illegal character: '#'
#define trace4(a, b, c, d) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << endl;
^
Main.java:93: error: illegal character: '#'
#define trace4(a, b, c, d) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << endl;
^
Main.java:93: error: illegal character: '#'
#define trace4(a, b, c, d) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << endl;
^
Main.java:93: error: illegal character: '#'
#define trace4(a, b, c, d) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << endl;
^
Main.java:94: error: illegal character: '#'
#define trace5(a, b, c, d, e) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << " | " << #e << ": " << e << endl;
^
Main.java:94: error: class, interface, or enum expected
#define trace5(a, b, c, d, e) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << " | " << #e << ": " << e << endl;
^
Main.java:94: error: illegal character: '#'
#define trace5(a, b, c, d, e) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << " | " << #e << ": " << e << endl;
^
Main.java:94: error: illegal character: '#'
#define trace5(a, b, c, d, e) cerr << #a << ": " << a << " | " << #b << ": " << b << " | " << #c << ": " << c << " | " << #d << ": " << d << " | " << #e << ": " << e << endl;
^
100 errors