牛客锦标赛

简介: 牛客锦标赛

题目描述


组委会正在为美团点评CodeM大赛的决赛设计新赛制。


比赛有 n 个人参加(其中 n 为2的幂),每个参赛者根据资格赛和预赛、复赛的成绩,会有不同的积分。比赛采取锦标赛赛制,分轮次进行,设某一轮有 m 个人参加,那么参赛者会被分为 m/2 组,每组恰好 2 人,m/2 组的人分别厮杀。我们假定积分高的人肯定获胜,若积分一样,则随机产生获胜者。获胜者获得参加下一轮的资格,输的人被淘汰。重复这个过程,直至决出冠军。


现在请问,参赛者小美最多可以活到第几轮(初始为第0轮)?


输入描述:

第一行一个整数 n (1≤n≤ 2^20),表示参加比赛的总人数。

接下来 n 个数字(数字范围:-1000000…1000000),表示每个参赛者的积分。

小美是第一个参赛者。

输出描述:

小美最多参赛的轮次。

输入示例

4
4 1 2 3

输出样例

2

方法一:DFS (85%的样例),

对于除了小美的参赛人员进行排序,每次小美都和其中几分最少的人进行比拼,如果小美的几分比这个最少的都要小,则说明小美这局会被淘汰.如果最终只剩下小美一个人,则说明小美是No1…

参考代码1

// 锦标赛 85% 
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
vector<int> v;
int n,cnt,num;
void dfs(int m){
  if(m==1){
    return;
  }
  if(v[0]>v[1]){
    cnt++;
  }else{
    return;
  }
  for(int i = 0;i<v.size();i++){
    if(v[i]>v[i+1]){
      v.erase(v.begin()+i+1);
    }else{
      v.erase(v.begin()+i);
    }
  }
  dfs(v.size());
}
int main()
{
  cin>>n;
  for(int i = 0; i < n;i++){
    cin>>num; 
    v.push_back(num);
  }
  sort(v.begin()+1,v.end());
  dfs(v.size());
  cout<<cnt<<endl;
  return 0;
}
相关文章
|
1月前
lanqiao OJ 182 小朋友崇拜圈
lanqiao OJ 182 小朋友崇拜圈
27 2
|
6月前
|
存储
每日一题——leetcode682.棒球比赛
每日一题——leetcode682.棒球比赛
|
6月前
|
Windows
孤独的树(牛客月赛)
孤独的树(牛客月赛)
38 0
|
算法 C语言 C++
LeetCode 每日一题2347. 最好的扑克手牌
给你一个整数数组 ranks 和一个字符数组 suit 。你有 5 张扑克牌,第 i 张牌大小
81 0
|
算法 测试技术
蓝桥杯2022年第十三届决赛真题-卡牌——二分法
蓝桥杯2022年第十三届决赛真题-卡牌——二分法
124 0
|
算法 C++ Python
【每日算法Day 87】今天我脱单了,所以大家不用做题了!
【每日算法Day 87】今天我脱单了,所以大家不用做题了!
122 0
|
Android开发
LeetCode 双周赛 98,脑筋急转弯转不过来!
大家好,我是小彭。 昨晚是 LeetCode 第 98 场双周赛,你参加了吗?这场周赛需要脑筋急转弯,转不过来 Medium 就会变成 Hard,转得过来就变成 Easy。
85 0
|
存储 人工智能 算法
【蓝桥杯集训·每日一题】AcWing 3305. 作物杂交
文章目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解 三、知识风暴 Spfa算法
120 0
|
存储 人工智能 JavaScript
【寒假每日一题】AcWing 4510. 寻宝!大冒险!
目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解
136 0
|
算法
初级算法之树
树比链表稍微复杂,因为链表是线性数据结构,而树不是。 树的问题可以由 广度优先搜索 或 深度优先搜索 解决。 在本章节中,我们提供了一个对于练习 广度优先遍历 很好的题目。 我们推荐以下题目: 二叉树的最大深度,验证二叉搜索树,二叉树的层次遍历 和 将有序数组转换为二叉搜索树。 剑指 Offer 55 - I. 二叉树的深度 输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。 递归法: class Solution { public int maxDepth(TreeNode root) {
50 0