设为首页 加入收藏

TOP

UVA11714 - Blind Sorting(推理)
2015-07-20 17:53:15 来源: 作者: 【 】 浏览:1
Tags:UVA11714 Blind Sorting 推理

题目链接


题意:给出n个数,求出得到最大数和第二大数所用的最多的比较次数

思路:可以取两个数两两做比较,就相当与建立二叉树,两个数的最大值就相当与两个的父节点,所以我们我们可以知道得到最大值时的比较次数为n-1,然后假设所有左儿子都大于右儿子,所以最大值的右儿子还有跟左子树中的值做比较得到第二大数,比较的个数为树高。

代码:

#include 
  
   
#include 
   
     #include 
    
      #include 
     
       #include 
      
        using namespace std; int n; int main() { while (scanf("%d", &n) != EOF) { int ans = n - 1 + (int)(ceil(log(n) / log(2))) - 1; printf("%d\n", ans); } return 0; }
      
     
    
   
  


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Data Race Free 的前世今生 下一篇POJ 1087 A Plug for UNIX(网络流..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: