#include <stdio.h>

void g1(int *a, int n, int i)

{

    while (2 * i <= n)

    {

        int j = 2 * i;

        int v = a[j - 1];

        if (j < n && v < a[j])

        {

            v = a[j];

            j += 1;

        }

 

        if (a[i - 1] < v)

        {

            int tmp = a[i - 1];

            a[i - 1] = v;

            a[j - 1] = tmp;

            i = j;

        } else

        {

            break;

        }

    }

}

 

int g2(int *a, int n, int m)

{

    int i;

    for (i = n / 2; i > 0; --i)

        g1(a, n, i);

 

    for (i = 0; i < n && a[i] != m; ++i);

 

    int j = 0;

    for (++i; i > 0; i /= 2)

        ++j;

 

    return j;

}

 

int main(int argc, char* argv[])

{

    int a[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16};

    int n = sizeof(a) / sizeof(a[0]);

    printf("%d", g2(a, n, 8));

    return 0;

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论