组委会正在为美团点评CodeM大赛的决赛设计新赛制。比赛有 n 个人参加(其中 n 为2的幂),每个参赛者根据资格赛和预赛、复赛的成绩,会有不同的积分。比赛采取锦标赛赛制,分轮次进行,设某一轮有
m 个人参加,那么参赛者会被分为 m/2 组,每组恰好 2 人,m/2 组的人分别厮杀。我们假定积分高的人肯定获胜,若积分一样,则随机产生获胜者。获胜者获得参加下一轮的资格,输的人被淘汰。重复这个过程,直至决出冠军。现在请问,参赛者小美最多可以活到第几轮(初始为第0轮)?
输入描述:
第一行一个整数 n (1≤n≤ 2^20),表示参加比赛的总人数。接下来 n 个数字(数字范围:-1000000…1000000),表示每个参赛者的积分。小美是第一个参赛者。输出描述:
小美最多参赛的轮次。示例1输入
复制4
4 1 2 3输出
复制2
emmm题目类型是dfs,但是我还是没找到跟dfs有啥关系。
模拟,首先先找到不大于小美分数的人数,然后将这些人进行比赛,计算能比多少轮,这样能最少浪费分数不大于小美的人数,来使小美能走的更远。若是选择分数低于小美的人与高于小美分数的人进行比赛,一定会被淘汰,则以后小美比赛时遇到的分数不高于自己的人数就会下降,那么将会使能走的论数更少。
emm,因为没有谷歌了,代码一粘贴复制就死机,所以把图片放上来。。。