> 文档中心 > 【Codeforces Round #794 (Div. 2)】【题解A-C】

【Codeforces Round #794 (Div. 2)】【题解A-C】

文章目录

  • A. Everything Everywhere All But One
  • B. Odd Subarrays
    • 题目详情:
    • 题解:
  • C. Circular Local MiniMax
    • 题目详情:
    • 题解:

A. Everything Everywhere All But One

题目详情:

给定一个包含 n 个整数 a1,a2,…,an 的数组。 用数组的 n-1 个元素,并用它们的算术平均值(不必是整数)替换它们中的每一个。 问:是否可以通过执行有限数量的此类操作来使数组的所有元素相等?

题解:

模拟题意即可。

#includeusing namespace std;typedef long long ll;typedef long double ld;typedef pair<int,int> pii;typedef vector<int> vi;typedef vector<pair<int,int>> vpii;#define all(a) a.begin(), a.end()#define nl '\n'const int inf=0x3f3f3f3f;const int maxn=1e6+5;void solve(){    int n;    cin >> n;    int sum = 0;    vi a(n);    for (int i = 0; i < n;i++){ cin >> a[i]; sum += a[i];    }    int flag = 0;    for (int i = 0; i < n;i++){ if(a[i]==floor(sum-a[i])/(n-1)){     flag = 1;     break; }    }    if (flag){ cout << "yes" << nl;    }    else{ cout << "no" << nl;    }}int main(){    ios::sync_with_stdio(0);    int t = 1;    cin>>t;    while(t--) solve();    return 0;}

B. Odd Subarrays

题目详情:

对于数组 [ b 1 , b 2 , … , b m ] [b_1,b_2,…,b_m] [b1,b2,,bm],将其反转次数定义为整数对 ( i , j ) (i,j) (i,j) 的数量,使得 1 ≤ i < j ≤ m 1≤i<j≤m 1i<jm b i > b j b_i>b_j bi>bj。 如果数组 b b b 的反转次数是奇数,我们就称它为奇数。

例如,数组 [4,2,7] 是奇数,因为它的反转次数是 1,而数组 [2,1,4,3] 不是,因为它的反转次数是 2。

给定一个从 1 到 n 的整数排列 [p1,p2,…,pn](每个整数在排列中只出现一次)。 您想将其拆分为几个连续的子数组(可能只有一个),以便其中奇数子数组的数量尽可能大

题解:

考虑相邻逆序数的对数。

#includeusing namespace std;typedef long long ll;typedef long double ld;typedef pair<int,int> pii;typedef vector<int> vi;typedef vector<pair<int,int>> vpii;#define all(a) a.begin(), a.end()#define nl '\n'#define debug() cout << "debug:"const int inf=0x3f3f3f3f;const int maxn=1e6+5;void solve(){    int n;    cin >> n;    int a[n];    for (int i = 0; i < n; i++) cin >> a[i];    int c = 0;    for (int i = 0; i < n - 1; i++){ if (a[i] > a[i + 1]){     //cout << a[i] << " " << a[i + 1];     c++;     i++; }    }    //debug();    cout << c << nl;}int main(){    ios::sync_with_stdio(0);    int t = 1;    cin>>t;    while(t--) solve();    return 0;}

C. Circular Local MiniMax

题目详情:

给你 n 个整数 a1,a2,…,an。是否可以将它们排列在一个圆圈上,以使每个数字都严格大于其邻居或严格小于其邻居?

换句话说,检查是否存在整数 a1,a2,…,an 的重排 b1,b2,…,bn 使得对于从 1 到 n 的每个 i,至少满足以下条件之一:

  • bi−1 bi+1
  • bi−1> bi < bi+1

为了理解前面关于 i=1 和 i=n 的公式,我们应该定义 b0=bn 和 bn+1=b1。

输入
输入的第一行包含一个整数 t (1≤t≤3⋅10^4) — 测试用例的数量。测试用例的描述如下。

每个测试用例的第一行包含一个整数 n (3≤n≤10^5) — 整数的个数。

每个测试用例的第二行包含 n 个整数 a1,a2,…,an (0≤ai≤10^9)。

所有测试用例的 n 总和不超过 2⋅10^5。

输出
对于每个测试用例,如果不能将满足语句条件的数字排列在圆圈上,则输出 NO。您可以在任何情况下输出每个字母。

否则,输出YES。在第二行中,输出 n 个整数 b1,b2,…,bn,它们是 a1,a2,…,an 的重新排列,并满足语句中的条件。如果有多种有效的排列数字的方法,您可以输出其中任何一种。

inputCopy431 1 241 9 8 442 0 2 261 1 1 11 111 1111outputCopyNOYES1 8 4 9 NOYES1 11 1 111 1 1111 

题解:

#include using namespace std;typedef long long ll;typedef long double ld;typedef pair<int, int> pii;typedef vector<int> vi;typedef vector<pair<int, int>> vpii;#define all(a) a.begin(), a.end()#define nl '\n'#define debug() cout << "debug:";const int inf = 0x3f3f3f3f;const int maxn = 1e6 + 5;int a[maxn], b[maxn];void solve(){    int n;    cin >> n;    for (int i = 0; i < n; ++i) cin >> a[i];    if (n & 1) return cout << "NO\n", void();    sort(a, a + n);    int m = n >> 1;    for (int i = 0; i < m; ++i) b[i * 2] = a[i], b[i * 2 + 1] = a[i + m];    for (int i = 1; i < n; ++i) if (b[i] == b[i - 1])     return cout << "NO\n", void();    cout << "YES\n";    for (int i = 0; i < n; ++i) cout << b[i] << ' ';    cout << '\n';}int main(){    ios::sync_with_stdio(0);    int t = 1;    cin >> t;    while (t--) solve();    return 0;}

开发者涨薪指南 【Codeforces Round #794 (Div. 2)】【题解A-C】 48位大咖的思考法则、工作方式、逻辑体系