本题主要考察观察力,首先找最小的例子:相邻两个数序号差为1,所以两个数的差必须大于等于1,由此发现数组必须严格递增或递减,不然无法满足这个条件。
于是我们排序后遍历看是否有两个数相同即可
```void solve() {
int t;
cin >> t;
while (t--) {
int n;
cin >> n;
vector<int> arr(n + 1);
for (int i = 1; i <= n; i++) {
cin >> arr[i];
}
if (n == 1) {
cout << arr[1] << endl;
} else {
sort(arr.begin(), arr.end());
bool furina = true;
for (int i = 1; i < n; i++) {
if (arr[i] == arr[i + 1]) {
furina = false;
cout << -1 << endl;
break;
}
}
if (furina) {
for (int i = 1; i <= n; i++) {
cout << arr[i] << ' ';
}
cout << endl;
}
}
}
}

京公网安备 11010502036488号