C. Challenging Cliffs

time limit per test

2 seconds

memory limit per test

256 megabytes

You are a game designer and want to make an obstacle course. The player will walk from left to right. You have n heights of mountains already selected and want to arrange them so that the absolute difference of the heights of the first and last mountains is as small as possible.

In addition, you want to make the game difficult, and since walking uphill or flat is harder than walking downhill, the difficulty of the level will be the number of mountains i (1≤i<n) such that hi≤hi+1 where hi is the height of the i-th mountain. You don't want to waste any of the mountains you modelled, so you have to use all of them.

From all the arrangements that minimize |h1−hn|, find one that is the most difficult. If there are multiple orders that satisfy these requirements, you may find any.

Input

The first line will contain a single integer t (1≤t≤100) --- the number of test cases. Then t test cases follow.

The first line of each test case contains a single integer n (2≤n≤2⋅105) --- the number of mountains.

The second line of each test case contains n integers h1,...,hn (1≤hi≤109), where hi is the height of the i-th mountain.

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

Output

For each test case, output n integers --- the given heights in an order that maximizes the difficulty score among all orders that minimize |h1−hn|.

If there are multiple orders that satisfy these requirements, you may output any.

Example

Input

Copy

复制代码
2
4
4 2 1 2
2
3 1

Output

Copy

复制代码
2 4 1 2 
1 3

Note

In the first test case:

The player begins at height 2, next going up to height 4 increasing the difficulty by 1. After that he will go down to height 1 and the difficulty doesn't change because he is going downhill. Finally the player will go up to height 2 and the difficulty will increase by 1. The absolute difference between the starting height and the end height is equal to 0 and it's minimal. The difficulty is maximal.

In the second test case:

The player begins at height 1, next going up to height 3 increasing the difficulty by 1. The absolute difference between the starting height and the end height is equal to 2 and it's minimal as they are the only heights. The difficulty is maximal.

解题说明:此题是一道模拟题,采用贪心算法, 首先从小到大排序后找到2个下标x,y 使得abs(h[x]-h[y])最小 ,可以发现 1 <= i < x 时 h[i] <= h[i+1] y <= i < n 时h[i] <= h[i+1] 所以把y到n中的数放前面 把1到x中的数放后面 当h[1]!=h[n]的时候 h[i] <= h[i+1]的i的个数最大为n-2 ,当h[1]==h[n]的时候 为n-1。

cpp 复制代码
#include <bits/stdc++.h>
#include<iostream>
#include<algorithm>
using namespace std;

int main()
{
	int t, n, i; 
	cin >> t;
	while (t--)
	{
		cin >> n; 
		int a[n], m = INT_MAX, j;
		for (i = 0; i < n; i++)
		{
			cin >> a[i];
		}
		sort(a, a + n);
		for (i = 1; i < n; i++) 
		{
			if (a[i] - a[i - 1] < m)
			{
				m = a[i] - a[i - 1];
				j = i;
			}
		} 
		cout << a[j - 1] << " ";
		for (i = j + 1; i < n; i++)
		{
			cout << a[i] << " ";
		}
		for (i = 0; i < j - 1; i++)
		{
			cout << a[i] << " ";
		}
		cout << a[j] << endl;
	}
	return 0;
}
相关推荐
橘子编程4 分钟前
GoF 23 种设计模式完整知识总结与使用教程
java·c语言·开发语言·python·设计模式
玖釉-6 分钟前
告别 Shared Memory 瓶颈:Vulkan Subgroup 架构解析与硬核实战指南
开发语言·c++·windows·图形渲染
lly2024068 分钟前
SQL UPDATE 语句详解
开发语言
君以思为故9 分钟前
认识Linux -- 线程同步与互斥
java·开发语言
吴梓穆11 分钟前
UE5 C++ 两种枚举
开发语言·c++·ue5
飞Link12 分钟前
pprint 全量技术手册:复杂数据结构的结构化输出引擎
开发语言·前端·python
意疏13 分钟前
【C语言】解决VScode中文乱码问题
c语言·开发语言·vscode
星辰徐哥14 分钟前
异步定时任务系统的设计与Rust实战集成
开发语言·后端·rust
被摘下的星星14 分钟前
Java接口需要注意的细节
java·开发语言
独特的螺狮粉18 分钟前
开源鸿蒙跨平台Flutter开发:手机清理小助手应用
开发语言·flutter·游戏·智能手机·开源·harmonyos·鸿蒙