A. Average Height(找相邻的数除2产生整数更多的排列)(codeforces715)

简介: A. Average Height(找相邻的数除2产生整数更多的排列)(codeforces715)

time limit per test1 second

memory limit per test256 megabytes

inputstandard input

outputstandard output

Sayaka Saeki is a member of the student council, which has n other members (excluding Sayaka). The i-th member has a height of ai millimeters.


It’s the end of the school year and Sayaka wants to take a picture of all other members of the student council. Being the hard-working and perfectionist girl as she is, she wants to arrange all the members in a line such that the amount of photogenic consecutive pairs of members is as large as possible.


A pair of two consecutive members u and v on a line is considered photogenic if their average height is an integer, i.e. (au+av)/2 is an integer.


Help Sayaka arrange the other members to maximize the number of photogenic consecutive pairs.


Input

The first line contains a single integer t (1≤t≤500) — the number of test cases.


The first line of each test case contains a single integer n (2≤n≤2000) — the number of other council members.


The second line of each test case contains n integers a1, a2, …, an (1≤ai≤2⋅105) — the heights of each of the other members in millimeters.


It is guaranteed that the sum of n over all test cases does not exceed 2000.


Output

For each test case, output on one line n integers representing the heights of the other members in the order, which gives the largest number of photogenic consecutive pairs. If there are multiple such orders, output any of them.


Example


inputCopy

4

3

1 1 2

3

1 1 1

8

10 9 13 15 3 16 9 13

2

18 9


outputCopy

1 1 2

1 1 1

13 9 13 15 3 9 16 10

9 18


Note

In the first test case, there is one photogenic pair: (1,1) is photogenic, as (1+1)/2=1 is integer, while (1,2) isn’t, as (1+2)/2=1.5 isn’t integer.


题意就是产生相邻的数除2产生整数更多的排列打印出来,我们就可以想到先排偶数然后在排奇数就可以得到最优排列,


听懂了记得给个赞鼓励一下,码字不易,用爱发电。


上ac代码。

f58230e9f063709cf3167704f4efdf14.gif


有事你就q我;QQ2917366383


学习算法

 

#include<iostream>
using namespace std;
const int maxn=1e6+7;
#define  ll long long
ll a[maxn];
int main()
{
  int t;
  cin>>t;
  while(t--)
  {
    int n;
    cin>>n;
    for(int i=1;i<=n;i++)
    {
      cin>>a[i];
    }
    for(int i=1;i<=n;i++)
    {
      if(a[i]%2==1)
      cout<<a[i]<<' ';
    }
      for(int i=1;i<=n;i++)
    {
      if(a[i]%2==0)
      cout<<a[i]<<' ';
    }
  }
}
相关文章
|
2月前
|
人工智能
PTA-求最大值及其下标
求最大值及其下标
20 0
|
2月前
|
人工智能 SDN
PTA-求3×4数组中大于等于平均值的元素的和
求3×4数组中大于等于平均值的元素的和
31 1
|
2月前
|
人工智能
PTA-求一组数中大于平均值的数的和
求一组数中大于平均值的数的和
36 0
|
2月前
|
算法 测试技术 C#
【map】【动态规划】LeetCode2713:矩阵中严格递增的单元格数
【map】【动态规划】LeetCode2713:矩阵中严格递增的单元格数
|
11月前
在Word中让公式在中间,公式编号右对齐
在Word中让公式在中间,公式编号右对齐
51nod 1277 字符串中的最大值 (后缀数组求height[i])
51nod 1277 字符串中的最大值 (后缀数组求height[i])
45 0
(二维vector)(绝对值求和等式的处理)B. Playing in a Casino
(二维vector)(绝对值求和等式的处理)B. Playing in a Casino
69 0
LeetCode 5340. 统计有序矩阵中的负数 Count Negative Numbers in a Sorted Matrix
LeetCode 5340. 统计有序矩阵中的负数 Count Negative Numbers in a Sorted Matrix
|
存储
矩阵转置(mooc)用户输入矩阵阶数,然后按行输入所有矩阵元素(整数),将该矩阵转置输出。阶数应是[1,5]之间的整数,不在该区间时,显示“matrix order error”。
矩阵转置(mooc)用户输入矩阵阶数,然后按行输入所有矩阵元素(整数),将该矩阵转置输出。阶数应是[1,5]之间的整数,不在该区间时,显示“matrix order error”。
76 0
|
机器学习/深度学习
Codeforces1499——C. Minimum Grid Path(思维+分奇偶+贪心)
Codeforces1499——C. Minimum Grid Path(思维+分奇偶+贪心)
74 0