D2 - Sage's Birthday (hard version)
看起来比较麻烦,但实际上,就是排序,然后分成大数组和小数组,然后交叉一下就好了.....这样我们可以最大化组合数为 ( n − 1 ) / 2
就是说会有相等的...加个特判就好(还是把小的插大的里,就是如果有相等的就不能加ans的数)
#include <iostream> #include <stack> #include <vector> #include <math.h> #include <string> #include <algorithm> #include <unordered_map> #include <map> #include<set> #include <cstring> using namespace std; const int maxn=1e5+3; int main() { int n; int a[maxn]; int b[maxn]; int ans = 0; vector<int> v; cin >> n; for (int i = 1; i <= n; ++i) { cin >> a[i]; } sort(a + 1, a + n + 1); // for (int j = 1,k = 1; k<=((n%2)?n+1:n) ; ++j,k+=2) { // b[k]=a[j+n/2];//第一位是个大的 // b[k+1]=a[j]; // } if (n % 2) { for (int i = 1, j = i + n / 2; i <= n / 2; i++, j++) { v.push_back(a[j]); v.push_back(a[i]); } v.push_back(a[n]); } else { for (int i = 1, j = i + n / 2; i <= n / 2; i++, j++) { v.push_back(a[j]); v.push_back(a[i]); } } for (int l = 1; l < n; ++l) { if (v[l - 1] > v[l] && v[l + 1] > v[l]) ans++; } cout << ans << endl; for (vector<int>::iterator k = v.begin(); k != v.end(); ++k) { cout << *k; if (k != v.end()-1) cout << " "; } return 0; }
为了自己,和那些爱你的人
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人