Always keep a beginner's|

Tobaa

园龄:1年1个月粉丝:1关注:1

[CSP-S 2024] 决斗

思路:刚开这道题就想到了二分,排序后找到每个元素比它第一个大的元素,由于 1n105 ,直接暴力查找的话复杂度接近 O(n2),会超时,所以用二分。感觉思路并不复杂,代码+调试15分钟搞定,可惜今年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 中国大陆许可协议进行许可。

posted @   Tobaa  阅读(25)  评论(1编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起