Q值。取一个长度为n的数组,其中所有数字都是非负且唯一的。找到具有最高值的数组中的元素。将元素拆分为两部分,其中第一部分包含数组中的下一个最高值,第二部分包含所需的附加实体以获得最高值。打印最高值分割为这两部分的数组。 样本输入:4 8 6 3 2 样品输出:4 6 2 6 3 2
#include <array>
#include <iostream>
using namespace std;
int main () {
int n, i, b, c, m;
cin >> n;
int a[ n ];
int z[ n + 1 ];
b = a[ 0 ];
c = a[ 0 ];
for (i = 0; i < n; i++)
cin >> a[ i ];
for (i = 0; i < n; i++) {
if (b < a[ i ])
b = a[ i ];
}
for (i = 0; i < n; i++) {
if (c < a[ i ] && a[ i ] != b)
c = a[ i ];
if (a[ i ] == b)
m = i;
}
for (i = 0; i < m; i++) {
z[ i ] = a[ i ];
}
for (i = m + 2; i < n + 1; i++) {
z[ i ] = a[ i - 1 ];
}
z[ m ] = c;
z[ m + 1 ] = b - c;
for (i = 0; i < n + 1; i++)
cout << z[ i ] << endl;
return 0;
}
答案 0 :(得分:1)
array不是库。您必须删除:
#include <array>