Algorithm


A. Adjacent Replacements
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Mishka got an integer array a of length n as a birthday present (what a surprise!).

Mishka doesn't like this present and wants to change it somehow. He has invented an algorithm and called it "Mishka's Adjacent Replacements Algorithm". This algorithm can be represented as a sequence of steps:

  • Replace each occurrence of 11 in the array a with 22;
  • Replace each occurrence of 22 in the array a with 11;
  • Replace each occurrence of 33 in the array a with 44;
  • Replace each occurrence of 44 in the array a with 33;
  • Replace each occurrence of 55 in the array a with 66;
  • Replace each occurrence of 66 in the array a with 55;
  • Replace each occurrence of 1091109−1 in the array a with 109109;
  • Replace each occurrence of 109109 in the array a with 1091109−1.

Note that the dots in the middle of this algorithm mean that Mishka applies these replacements for each pair of adjacent integers (2i1,2i2�−1,2�) for each i{1,2,,5108}�∈{1,2,…,5⋅108} as described above.

For example, for the array a=[1,2,4,5,10]�=[1,2,4,5,10], the following sequence of arrays represents the algorithm:

[1,2,4,5,10][1,2,4,5,10]  (replace all occurrences of 11 with 22 [2,2,4,5,10][2,2,4,5,10]  (replace all occurrences of 22 with 11 [1,1,4,5,10][1,1,4,5,10]  (replace all occurrences of 33 with 44 [1,1,4,5,10][1,1,4,5,10]  (replace all occurrences of 44 with 33 [1,1,3,5,10][1,1,3,5,10]  (replace all occurrences of 55 with 66 [1,1,3,6,10][1,1,3,6,10]  (replace all occurrences of 66 with 55 [1,1,3,5,10][1,1,3,5,10]    [1,1,3,5,10][1,1,3,5,10]  (replace all occurrences of 1010 with 99 [1,1,3,5,9][1,1,3,5,9]. The later steps of the algorithm do not change the array.

Mishka is very lazy and he doesn't want to apply these changes by himself. But he is very interested in their result. Help him find it.

Input

The first line of the input contains one integer number n (1n10001≤�≤1000) — the number of elements in Mishka's birthday present (surprisingly, an array).

The second line of the input contains n integers a1,a2,,an�1,�2,…,�� (1ai1091≤��≤109) — the elements of the array.

Output

Print n integers — b1,b2,,bn�1,�2,…,��, where bi�� is the final value of the i-th element of the array after applying "Mishka's Adjacent Replacements Algorithm" to the array a. Note that you cannot change the order of elements in the array.

Examples
input
Copy
5
1 2 4 5 10
output
Copy
1 1 3 5 9
input
Copy
10
10000 10 50605065 1 5 89 5 999999999 60506056 1000000000
output
Copy
9999 9 50605065 1 5 89 5 999999999 60506055 999999999
Note

The first example is described in the problem statement.

 

Code Examples

#1 Code Example with C++ Programming

Code - C++ Programming

#include <bits/stdc++.h>

using namespace std;

int const N = 1001;
int n, a[N];

int main() {
  cin >> n;
  for(int i = 0; i < n; ++i)
    cin >> a[i];
  
  for(int i = 0; i < n; ++i)
    printf("%s%d", i == 0 ? "" : " ", a[i] - (a[i] % 2 == 0));
  puts("");
  
  return 0;
}
Copy The Code & Try With Live Editor

Input

x
+
cmd
5
1 2 4 5 10

Output

x
+
cmd
1 1 3 5 9
Advertisements

Demonstration


Codeforces Solution-A. Adjacent Replacements-Solution in C, C++, Java, Python,Adjacent Replacements,Codeforces Solution

Previous
Codeforces solution 1080-B-B. Margarite and the best present codeforces solution
Next
CodeChef solution DETSCORE - Determine the Score CodeChef solution C,C+