// Đạt đz s1 tg
#include <bits/stdc++.h>
#define f first
#define s second
#define mod 1000000007
#define PB push_back
#define PF push_front
#define inf 10000007
#define round(m,n) setprecision((int)m) << fixed << double(n)
#define ll long long
#define int long long
#define bit(x, i) ((x >> i) & 1)
#define pii pair<int, int>
#define TASK "B"
using namespace std;
void ADD(int &x, int y){
x += y;
if (x >= mod) x -= mod;
if (x < 0) x += mod;
}
int n, m;
int a[100005];
vector<int> adj[100005], ao[100005];
int vis[100005], f[100005], gay[100005];
pii edge[100005];
int ShortestPass(int st){
memset(vis, 0, sizeof(vis));
for(int i = 1; i <= n; i++)
f[i] = mod;
f[st] = a[st];
priority_queue<pii, vector<pii>, greater<pii>> q;
q.push({a[st], st});
while(q.size()){
int u = q.top().s;
int w = q.top().f;
q.pop();
vis[u] = 1;
for(int v : adj[u])
if(!vis[v] && f[v] > w + a[v]){
f[v] = w + a[v];
q.push({f[v], v});
}
}
return f[n];
}
int cnt = 0, scc = 0, low[100005], num[100005], inst[100005];
vector<vector<int>> G;
stack<int> st;
void Tarjan(int u){
num[u] = low[u] = ++cnt;
st.push(u);
inst[u] = true;
for(int v : adj[u]){
if(num[v] == 0){
Tarjan(v);
low[u] = min(low[u], low[v]);
}
else if(inst[v]){
low[u] = min(low[u], num[v]);
}
}
if(low[u] == num[u]){
vector<int> s;
int v = mod;
while(v != u){
v = st.top();
st.pop();
inst[v] = false;
s.PB(v);
}
G.PB(s);
++scc;
}
}
int save[100005];
int NoLeSieuGay(int st){
memset(vis, 0, sizeof(vis));
for(int i = 1; i <= n; i++)
f[i] = 0;
f[st] = gay[st];
priority_queue<pii> q;
q.push({gay[st], st});
while(q.size()){
int u = q.top().s;
int w = q.top().f;
q.pop();
vis[u] = 1;
for(int v : ao[u])
if(!vis[v] && f[v] < w + gay[v]){
f[v] = w + gay[v];
q.push({f[v], v});
}
}
return f[save[n]];
}
int Longlong(){
for(int i = 1; i <= n; i++)
if(num[i] == 0) Tarjan(i);
int ans = 0, cur = 0;
for(int i = 0; i < scc; i++){
int sum = 0;
for(auto v : G[i]){
save[v] = i;
gay[i] += a[v];
}
}
for(int i = 1; i <= m; i++){
ao[save[edge[i].f]].PB(save[edge[i].s]);
}
return NoLeSieuGay(save[1]);
}
signed main(){
ios_base::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
if(fopen(TASK".INP", "r")){
freopen(TASK".INP", "r", stdin);
freopen(TASK".OUT", "w", stdout);
}
cin >> n >> m;
for(int i = 1; i <= n; i++)
cin >> a[i];
for(int i = 1; i <= m; i++){
int u, v;
cin >> u >> v;
adj[u].PB(v);
edge[i] = {u, v};
}
pii Ans = make_pair(ShortestPass(1), Longlong());
if(Ans.f >= mod){
cout << -1;
return 0;
}
else cout << Ans.f << " " << Ans.s;
}
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int INF = 0x3f3f3f3f3f3f3f3f;
const int N = 1e5 + 10;
int n, m;
int a[N];
vector<int> adj[N], radj[N], adj2[N];
pair<int, int> edges[N];
int comp[N], vis[N], scc = 0;
int cw[N], indeg[N], dp[N];
vector<int> order;
void owo() {
vector<int> dist(n + 1, INF);
priority_queue<pair<int, int>, vector<pair<int, int>>, greater<>> pq;
dist[1] = a[1];
pq.emplace(dist[1], 1);
while (!pq.empty()) {
auto [d, u] = pq.top(); pq.pop();
if (d > dist[u]) continue;
for (int v : adj[u]) {
if (dist[v] > dist[u] + a[v]) {
dist[v] = dist[u] + a[v];
pq.emplace(dist[v], v);
}
}
}
cout << (dist[n] == INF ? -1 : dist[n]) << '\n';
}
void dfs1(int u) {
vis[u] = true;
for (int v : adj[u])
if (!vis[v]) dfs1(v);
order.push_back(u);
}
void dfs2(int u) {
comp[u] = scc;
for (int v : radj[u])
if (comp[v] == -1) dfs2(v);
}
void uwu() {
memset(comp, -1, sizeof comp);
memset(dp, -0x3f, sizeof dp);
for (int i = 1; i <= n; i++)
if (!vis[i]) dfs1(i);
for (int i = (int)order.size() - 1; i >= 0; i--)
if (comp[order[i]] == -1)
dfs2(order[i]), ++scc;
for (int i = 1; i <= n; i++)
cw[comp[i]] += a[i];
for (int i = 0; i < m; i++) {
auto [u, v] = edges[i];
if (comp[u] != comp[v]) {
adj2[comp[u]].push_back(comp[v]);
++indeg[comp[v]];
}
}
int s = comp[1], t = comp[n];
dp[s] = cw[s];
queue<int> q;
for (int i = 0; i < scc; i++)
if (indeg[i] == 0) q.push(i);
while (!q.empty()) {
int u = q.front(); q.pop();
for (int v : adj2[u]) {
if (dp[u] > -INF)
dp[v] = max(dp[v], dp[u] + cw[v]);
if (--indeg[v] == 0)
q.push(v);
}
}
cout << (dp[t] < 0 ? -1 : dp[t]) << '\n';
}
signed main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
cin >> n >> m;
for (int i = 1; i <= n; i++) cin >> a[i];
for (int i = 0; i < m; i++) {
int u, v;
cin >> u >> v;
adj[u].push_back(v);
radj[v].push_back(u);
edges[i] = {u, v};
}
vector<bool> mark(n + 1, false);
mark[1] = true;
queue<int> q;
q.push(1);
while (!q.empty()) {
int u = q.front(); q.pop();
for (int v : adj[u])
if (!mark[v]) {
mark[v] = true;
q.push(v);
}
}
if (!mark[n]) {
cout << "-1\n";
return 0;
}
owo();
uwu();
return 0;
}
#include <bits/stdc++.h>
#define For(i,x,n) for(int (i)=(int)(x);(i)<=(int)(n);(i)++)
#define int long long
#define down "\n"
using namespace std;
// Hàm tạo số ngẫu nhiên trong khoảng [L, R]
int UID(int L, int R) {
static mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
return uniform_int_distribution<int>(L, R)(rng);
}
signed main()
{
int N = UID(2, 100000);
int M = UID(N-1, min(100000, N * 10)); // Ensure at least a path is possible, but not too dense
cout << N << " " << M << '\n';
// Importance values a[i]
for (int i = 0; i < N; ++i) {
cout << UID(1, 1000) << " ";
}
cout << '\n';
set<pair<int, int>> edges;
// Ensure at least a path from 1 to N exists
for (int i = 1; i < N; ++i) {
int u = i;
int v = i + 1;
edges.insert({u, v});
cout << u << " " << v << '\n';
}
// Add remaining random edges
while ((int)edges.size() < M) {
int u = UID(1, N);
int v = UID(1, N);
if (u != v && !edges.count({u, v})) {
edges.insert({u, v});
cout << u << " " << v << '\n';
}
}
return 0;
}
// Đạt đz s1 tg

#include <bits/stdc++.h>

#define f first
#define s second
#define mod 1000000007
#define PB push_back
#define PF push_front
#define inf 10000007
#define round(m,n) setprecision((int)m) << fixed << double(n)
#define ll long long
#define int long long
#define bit(x, i) ((x >> i) & 1)
#define pii pair<int, int>
#define TASK "B"

using namespace std;

void ADD(int &x, int y){
    x += y;
    if (x >= mod) x -= mod;
    if (x < 0) x += mod;
}

int n, m;
int a[100005];
vector<int> adj[100005], ao[100005];
int vis[100005], f[100005], gay[100005];
pii edge[100005];

int ShortestPass(int st){
    memset(vis, 0, sizeof(vis));
    for(int i = 1; i <= n; i++)
        f[i] = mod;
    f[st] = a[st];
    priority_queue<pii, vector<pii>, greater<pii>> q;
    q.push({a[st], st});
    while(q.size()){
        int u = q.top().s;
        int w = q.top().f;
        q.pop();
        vis[u] = 1;
        for(int v : adj[u])
        if(!vis[v] && f[v] > w + a[v]){
            f[v] = w + a[v];
            q.push({f[v], v});
        }
    }

    return f[n];
}

int cnt = 0, scc = 0, low[100005], num[100005], inst[100005];
vector<vector<int>> G;
stack<int> st;

void Tarjan(int u){
    num[u] = low[u] = ++cnt;
    st.push(u);
    inst[u] = true;

    for(int v : adj[u]){
        if(num[v] == 0){
            Tarjan(v);
            low[u] = min(low[u], low[v]);
        }
        else if(inst[v]){
            low[u] = min(low[u], num[v]);
        }
    }

    if(low[u] == num[u]){
        vector<int> s;
        int v = mod;
        while(v != u){
            v = st.top();
            st.pop();
            inst[v] = false;
            s.PB(v);
        }
        G.PB(s);
        ++scc;
    }
}

int save[100005];

int NoLeSieuGay(int st){
    memset(vis, 0, sizeof(vis));
    for(int i = 1; i <= n; i++)
        f[i] = 0;
    f[st] = gay[st];
    priority_queue<pii> q;
    q.push({gay[st], st});
    while(q.size()){
        int u = q.top().s;
        int w = q.top().f;
        q.pop();
        vis[u] = 1;
        for(int v : ao[u])
        if(!vis[v] && f[v] < w + gay[v]){
            f[v] = w + gay[v];
            q.push({f[v], v});
        }
    }

    return f[save[n]];
}

int Longlong(){
    for(int i = 1; i <= n; i++)
        if(num[i] == 0) Tarjan(i);

    int ans = 0, cur = 0;
    for(int i = 0; i < scc; i++){
        int sum = 0;
        for(auto v : G[i]){
            save[v] = i;
            gay[i] += a[v];
        }
    }

    for(int i = 1; i <= m; i++){
        ao[save[edge[i].f]].PB(save[edge[i].s]);
    }

    return NoLeSieuGay(save[1]);
}

signed main(){
    ios_base::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);

    if(fopen(TASK".INP", "r")){
        freopen(TASK".INP", "r", stdin);
        freopen(TASK".OUT", "w", stdout);
    }

    cin >> n >> m;
    for(int i = 1; i <= n; i++)
        cin >> a[i];

    for(int i = 1; i <= m; i++){
        int u, v;
        cin >> u >> v;
        adj[u].PB(v);
        edge[i] = {u, v};
    }

    pii Ans = make_pair(ShortestPass(1), Longlong());
    if(Ans.f >= mod){
        cout << -1;
        return 0;
    }
    else cout << Ans.f << " " << Ans.s;
}
#include <bits/stdc++.h>
#define int long long
using namespace std;

const int INF = 0x3f3f3f3f3f3f3f3f;
const int N = 1e5 + 10;

int n, m;
int a[N];
vector<int> adj[N], radj[N], adj2[N];
pair<int, int> edges[N];

int comp[N], vis[N], scc = 0;
int cw[N], indeg[N], dp[N];
vector<int> order;

void owo() {
    vector<int> dist(n + 1, INF);
    priority_queue<pair<int, int>, vector<pair<int, int>>, greater<>> pq;
    dist[1] = a[1];
    pq.emplace(dist[1], 1);
    while (!pq.empty()) {
        auto [d, u] = pq.top(); pq.pop();
        if (d > dist[u]) continue;
        for (int v : adj[u]) {
            if (dist[v] > dist[u] + a[v]) {
                dist[v] = dist[u] + a[v];
                pq.emplace(dist[v], v);
            }
        }
    }
    cout << (dist[n] == INF ? -1 : dist[n]) << '\n';
}

void dfs1(int u) {
    vis[u] = true;
    for (int v : adj[u])
        if (!vis[v]) dfs1(v);
    order.push_back(u);
}

void dfs2(int u) {
    comp[u] = scc;
    for (int v : radj[u])
        if (comp[v] == -1) dfs2(v);
}

void uwu() {
    memset(comp, -1, sizeof comp);
    memset(dp, -0x3f, sizeof dp);

    for (int i = 1; i <= n; i++)
        if (!vis[i]) dfs1(i);
    for (int i = (int)order.size() - 1; i >= 0; i--)
        if (comp[order[i]] == -1)
            dfs2(order[i]), ++scc;

    for (int i = 1; i <= n; i++)
        cw[comp[i]] += a[i];

    for (int i = 0; i < m; i++) {
        auto [u, v] = edges[i];
        if (comp[u] != comp[v]) {
            adj2[comp[u]].push_back(comp[v]);
            ++indeg[comp[v]];
        }
    }

    int s = comp[1], t = comp[n];
    dp[s] = cw[s];

    queue<int> q;
    for (int i = 0; i < scc; i++)
        if (indeg[i] == 0) q.push(i);

    while (!q.empty()) {
        int u = q.front(); q.pop();
        for (int v : adj2[u]) {
            if (dp[u] > -INF)
                dp[v] = max(dp[v], dp[u] + cw[v]);
            if (--indeg[v] == 0)
                q.push(v);
        }
    }

    cout << (dp[t] < 0 ? -1 : dp[t]) << '\n';
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    cin >> n >> m;
    for (int i = 1; i <= n; i++) cin >> a[i];
    for (int i = 0; i < m; i++) {
        int u, v;
        cin >> u >> v;
        adj[u].push_back(v);
        radj[v].push_back(u);
        edges[i] = {u, v};
    }

    vector<bool> mark(n + 1, false);
    mark[1] = true;
    queue<int> q;
    q.push(1);
    while (!q.empty()) {
        int u = q.front(); q.pop();
        for (int v : adj[u])
            if (!mark[v]) {
                mark[v] = true;
                q.push(v);
            }
    }

    if (!mark[n]) {
        cout << "-1\n";
        return 0;
    }

    owo();
    uwu();

    return 0;
}

#include <bits/stdc++.h>
#define For(i,x,n) for(int (i)=(int)(x);(i)<=(int)(n);(i)++)
#define int long long
#define down "\n"

using namespace std;

// Hàm tạo số ngẫu nhiên trong khoảng [L, R]
int UID(int L, int R) {
    static mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
    return uniform_int_distribution<int>(L, R)(rng);
}


signed main()
{
    int N = UID(2, 100000);
    int M = UID(N-1, min(100000, N * 10)); // Ensure at least a path is possible, but not too dense

    cout << N << " " << M << '\n';

    // Importance values a[i]
    for (int i = 0; i < N; ++i) {
        cout << UID(1, 1000) << " ";
    }
    cout << '\n';

    set<pair<int, int>> edges;

    // Ensure at least a path from 1 to N exists
    for (int i = 1; i < N; ++i) {
        int u = i;
        int v = i + 1;
        edges.insert({u, v});
        cout << u << " " << v << '\n';
    }

    // Add remaining random edges
    while ((int)edges.size() < M) {
        int u = UID(1, N);
        int v = UID(1, N);
        if (u != v && !edges.count({u, v})) {
            edges.insert({u, v});
            cout << u << " " << v << '\n';
        }
    }

    return 0;
}
