[CSP-S 2024] 决斗
思路:刚开这道题就想到了二分,排序后找到每个元素比它第一个大的元素,由于 可惜今年s组没过。
#include <bits/stdc++.h>
using namespace std;
const int N = 1e6+10;
int n, x;
struct bj {
int num;
bool flag, gjf;
};
vector<bj> v;
int bs(int k) {
int r = n - 1, l = 0, res = -1;
while (l <= r) {
int mid = l + (r - l) / 2;
if (v[mid].num > k && v[mid].flag == true && v[mid].gjf == true) {
res = mid;
r = mid - 1;
} else l = mid + 1;
}
return res;
}
bool cmp(bj a, bj b) {
return a.num < b.num;
}
int main() {
cin >> n;
for (int i = 0; i < n; i++) {
cin >> x;
v.push_back({x, true, true});
}
sort(v.begin(), v.end(), cmp);
for (int i = 0; i < n - 1; i++) {
int re = bs(v[i].num);
if (re == -1) continue;
else {
v[i].flag = false;
v[re].gjf = false;
}
}
int ans = 0;
for (int i = 0; i < n; i++)
if (v[i].flag == true) ans++;
cout << ans;
return 0;
}
本文作者:Tobaa
本文链接:https://www.cnblogs.com/TobyL/p/18637350
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步