牛客网——锦标赛(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;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!