贪心 思维 B. Combinatorics Homework Edu CF Round 114 (Div. 2)
题意
有a个字符A,b个字符B,c个字符C
需要构造恰好m个相邻位置相同的pair的字符串
exactly m pairs of adjacent equal letters (exactly m such positions i that the i-th letter is equal to the (i+1)-th one).
思路
贪心考虑上下界即可。其实就是连续的。
solution
#include <bits/stdc++.h> #define sc(x) scanf("%lld", &(x)) #define pr(x) printf("%lld\n", (x)) #define rep(i, l, r) for (int i = l; i <= r; ++i) using namespace std; typedef long long ll; const int N = 1e5 + 7; const int mod = 1e9 + 7; signed main() { ll T; sc(T); ll a[3], m; while (T--) { rep(i, 0, 2) sc(a[i]); sc(m); sort(a, a + 3); ll L = max(0LL, a[2] - a[1] - a[0] - 1); // 最短的排列方式就是 ABCABCABABAAAA // 但是需要注意的是可以 AACABCABABABAA // 所以需要再 - 1 ll R = a[0] + a[1] + a[2] - 3; // 最长的排列方式就是连续排列 if (m >= L && m <= R) puts("YES"); else puts("NO"); } return 0; }
算法竞赛之路 文章被收录于专栏
整理、记录算法竞赛的好题