我是靠谱客的博主 勤恳百褶裙,最近开发中收集的这篇文章主要介绍牛客网——锦标赛(80%通过)(DFS),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

没能AC但是通过了80%,使用的是递归的DFS,八成还是因为使用了递归使得复杂度太高,我也只是复习dfs递归的写法,目的也达到了就不改代码一定要它AC了。具体题目如下:

我的想法是将选手成绩存放到名为a的vector中,将1到n个升序排序(0是第一个序号,第一个是主人公的分数不用排序),然后两两比较,低分就erase掉,注意之一端是i++而不是i+=2:

	for (int i = 0; i < a.size(); i ++)
	{
		if (a[i] < a[i + 1])
			a.erase(a.begin() + i);
		else
			a.erase(a.begin() + i + 1);
	}

因为erase掉了一个就少了一个,所以自加1即可,如果i+=2的话会越界。以下是所有代码:

 

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
vector<int> a;
int ans = 0;


void dfs(int b)
{
	if (b == 1)return;

	sort(a.begin()+1,a.end());
	if (a[0] > a[1])ans++;
	else return;

	for (int i = 0; i < a.size(); i ++)
	{
		if (a[i] < a[i + 1])
			a.erase(a.begin() + i);
		else
			a.erase(a.begin() + i + 1);
	}
	dfs(a.size());

}


int main(void)
{
	int n;
	cin >> n;
	for (int i = 0; i < n; i++)
	{
		int temp;
		cin >> temp;
		a.push_back(temp);
	}
	dfs(n);
	cout << ans << endl;
	system("pause");
	return 0;
}

 

最后

以上就是勤恳百褶裙为你收集整理的牛客网——锦标赛(80%通过)(DFS)的全部内容,希望文章能够帮你解决牛客网——锦标赛(80%通过)(DFS)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部