Paint it really, really dark gray

I see a pink boar and I want it painted black. Black boars look much more awesome and mighty than the pink ones. Since Jaggy became the ruler of the forest, he has been trying his best to improve the diplomatic relations between the forest region and the nearby ones.

Some other rulers, however, have requested too much in return for peace between their two regions, so he realized he has to resort to intimidation. Once a delegate for diplomatic relations of a neighboring region visits Jaggy’s forest, if they see a whole bunch of black boars, they might suddenly change their mind about attacking Jaggy. Black boars are really scary, after all.

Jaggy’s forest can be represented as a tree (connected graph without cycles) with n vertices. Each vertex represents a boar and is colored either black or pink. Jaggy has sent a squirrel to travel through the forest and paint all the boars black. The squirrel, however, is quite unusually trained and while it traverses the graph, it changes the color of every vertex it visits, regardless of its initial color: pink vertices become black and black vertices become pink.

Since Jaggy is too busy to plan the squirrel’s route, he needs your help. He wants you to construct a walk through the tree starting from vertex 1 such that in the end all vertices are black. A walk is a sequence of vertices, such that every consecutive pair has an edge between them in a tree.

Input

The first line of input contains integer n (2 ≤ n ≤ 200 000), denoting the number of vertices in the tree. The following n lines contains n integers, which represent the color of the nodes.

If the i-th integer is 1, if the i-th vertex is black and  - 1 if the i-th vertex is pink.

Each of the next n - 1 lines contains two integers, which represent the indexes of the vertices which are connected by the edge. Vertices are numbered starting with 1.

Output

Output path of a squirrel: output a sequence of visited nodes’ indexes in order of visiting. In case of all the nodes are initially black, you should print 1. Solution is guaranteed to exist. If there are multiple solutions to the problem you can output any of them provided length of sequence is not longer than 107.

Example

input

5
1
1
-1
1
-1
2 5
4 3
2 4
4 1

output

1 4 2 5 2 4 3 4 1 4 1

Note

At the beginning squirrel is at node 1 and its color is black. Next steps are as follows:

  • From node 1 we walk to node 4 and change its color to pink.
  • From node 4 we walk to node 2 and change its color to pink.
  • From node 2 we walk to node 5 and change its color to black.
  • From node 5 we return to node 2 and change its color to black.
  • From node 2 we walk to node 4 and change its color to black.
  • We visit node 3 and change its color to black.
  • We visit node 4 and change its color to pink.
  • We visit node 1 and change its color to pink.
  • We visit node 4 and change its color to black.
  • We visit node 1 and change its color to black.

Solution:

#include <bits/stdc++.h>

using namespace std;

const int N = 1234567;

int c[N];
vector <int> g[N];

void put(int x) {
c[x] = -c[x];
printf(" %d", x + 1);
}

void dfs(int v, int pr) {
int sz = g[v].size();
for (int j = 0; j < sz; j++) {
    int u = g[v][j];
    if (u == pr) {
      continue;
    }
    put(u);
    dfs(u, v);
    put(v);
    if (c[u] == -1) {
      put(u);
      put(v);
    }
  }
  if (v == 0 && c[v] == -1) {
    int u = g[v][0];
    put(u);
    put(v);
    put(u);
  }
}

int main() {
  int n;
  scanf("%d", &n);
  for (int i = 0; i < n; i++) {
    scanf("%d", c + i);
  }
  for (int i = 0; i < n; i++) {
    g[i].clear();
  }
  for (int i = 0; i < n - 1; i++) {
    int foo, bar;
    scanf("%d %d", &foo, &bar);
    foo--; bar--;
    g[foo].push_back(bar);
    g[bar].push_back(foo);
  }
  printf("1");
  dfs(0, -1);
  return 0;
}