国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - C語言數據結構堆的基本操作實現

C語言數據結構堆的基本操作實現

2022-03-07 14:10許同學。。 C/C++

這篇文章主要為大家介紹了C語言數據結構堆的基本操作實現示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

1.基本函數實現

a.代碼1(向下調整)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
void AdjustDown(DateType*a, int n, int parent)
{
    int child = parent * 2 + 1;
    while (child<n)
    {
        if ((child+1) < n && a[child] > a[child + 1])
        {
            ++child;
        }
        if (a[parent] > a[child])
        {
            Swap(&a[parent], &a[child]);
            parent = child;
            child = parent * 2 + 1;
        }
        else
        {
            break;
        }
    }
}

注意:if里面的條件語句(child +1)<n是防止越界的,因為不能保證有右孩子。

b.代碼2(向上調整)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void AdjustUp(DateType*a , int child)
{
    int parent = (child - 1) / 2;
    while (child > 0)
    {
        if (a[child] < a[parent])
        {
            Swap(&a[child], &a[parent]);
            child = parent;
            parent = (child - 1) / 2;
        }
        else
        {
            break;
        }
    }
}

注意:while里面的條件語句是不能夠寫成(parent<0),因為當child==0時,parent=(child - 1) / 2,parent==0,再次進入循環不滿足a[child] < a[parent],恰好跳出循環。如果寫成(a[child] <= a[parent])就死循環了

c.代碼3(交換)

?
1
2
3
4
5
6
void Swap(DateType*p1, DateType*p2)
{
    DateType tmp = *p1;
    *p1 = *p2;
    *p2 = tmp;
}

2.建堆 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
void CreatHeap(Heap*p,DateType*num,int n)
{
    assert(p);
    p->a = (DateType*)malloc(n * sizeof(DateType));
    if (p->a == NULL)
    {
        printf("malloc failed\n");
        exit(-1);
    }
    memcpy(p->a, num, n * sizeof(DateType));
    p->size = n;
    p->capacity = n;
    //建小堆
    for (int i = (n - 1 - 1) / 2; i >= 0; i--)
    {
        AdjustDown(p->a, p->size, i);
    }
}

3.插入數據

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
void HeapPush(Heap*p, DateType x)
{
    assert(p);
    if (p->size == p->capacity)
    {
        DateType*tmp = (DateType*)realloc(p->a, (p->capacity) * 2 * sizeof(DateType));
        if (tmp == NULL)
        {
            printf("realloc  failed\n ");
            exit(-1);
        }
    }
    (p->capacity) *= 2;
    p->a[p->size] = x;
    ++(p->size);
    //向上調整
    AdjustUp(p->a, p->size-1);
}

4. 刪除數據

?
1
2
3
4
5
6
7
8
void HeapPop(Heap*p, DateType x)
{
    assert(p);
    Swap(&p->a[0], &p->a[p->size-1]);
    --(p->size);
    AdjustDown(p->a, p->size, 0);
    //左右子樹還是小堆,直接調整行了
}

把堆頂的數據與最后一個數據交換,再次調整size-1個數據。 

5.獲取堆頂的數據

?
1
2
3
4
5
DateType HeapTop(Heap*p)
{
    assert(p);
    return p->a[0];
}

6.堆的數據個數

?
1
2
3
4
5
int HeapSize(Heap*p)
{
    assert(p);
    return p->size;
}

7.判空

?
1
2
3
4
5
bool HeapIsEmpty(Heap*p)
{
    assert(p);
    return p->size == 0;
}

8.打印

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
void Print(Heap*p)
{
    assert(p);
    for (int i = 0; i < p->size; i++)
    {
        printf("%d ", (p->a)[i]);
    }
    printf("\n");
    int count = 0;//計數
    int levelsize = 1;
    for (int i = 0; i < p->size; i++)
    {
        printf("%d ", p->a[i]);
        ++count;
        if (count == levelsize)
        {
            printf("\n");
            levelsize *= 2;
            count = 0;//重新計數
        }
    }
    printf("\n");
}

9.銷毀

?
1
2
3
4
5
6
7
void HeapDestory(Heap*p)
{
    assert(p);
    free(p->a);
    p->a = NULL;
    p->capacity = p->size = 0;
}

10.測試

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
int main()
{
    int num[] = { 12,15,17,23,10,25 };
    int n = sizeof(num) / sizeof(num[0]);
    Heap a;
    //創建小堆
    CreatHeap(&a,num, n);
    Print(&a);
    printf("\n");
    //插入數據
    HeapPush(&a, 1);
    Print(&a);
    //刪除對頂的數據
    HeapPop(&a);
    Print(&a);
    printf("\n");
    //獲取堆頂數據
    int ret=HeapTop(&a);
    printf("The top date is %d\n",ret);
    //堆的數據個數
    int number=HeapSize(&a);
    printf("The number of heap is %d\n", number);
    //銷毀
    HeapDestory(&a);
    return 0;
}

11.測試結果

C語言數據結構堆的基本操作實現

12.用堆排序(降序)

a.代碼1

?
1
2
3
4
5
6
7
8
9
10
11
12
int main()
{
    DateType num[] = { 12,15,17,23,10,25 };
    int n = sizeof(num) / sizeof(num[0]);
    HeapSort(num, n);
    for (int i = 0; i < n; i++)
    {
        printf("%d ", num[i]);
    }
    printf("\n\n");
    return 0;
}
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
void HeapSort(int*num, int n)
{
    //建小堆
    for (int i = (n - 1 - 1) / 2; i >= 0; i--)
    {
        AdjustDown(num, n, i);
    }
    int end = n - 1;
    while (end>0)
    {
        Swap(&num[0], &num[end]);
        AdjustDown(num, end, 0);
        --end;
    }
}

運行結果

C語言數據結構堆的基本操作實現

堆的基本操作今天就分享在到這里了,謝謝你的瀏覽,如果對你有幫助的話請大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_59799963/article/details/121444793

延伸 · 閱讀

精彩推薦
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 日韩中文字幕在线观看 | 亚洲国产色视频 | 91麻豆精品国产91久久久资源速度 | 欧美一级片 | 免费在线黄视频 | av中文字幕在线 | 免费看黄色电影 | 日韩精品一区在线视频 | 久久高清| 欧美成人综合在线 | 欧美成人综合在线 | 日韩三级观看 | 91麻豆精品国产91久久久更新资源速度超快 | 国产精品99久久久久久动医院 | 欧美一级欧美三级在线观看 | 国产精品一区二区视频 | 亚洲免费在线视频 | 欧美精品一区二区三区蜜桃视频 | 久久国产精品久久久久久电车 | 欧美中文字幕一区 | 亚洲成人精品在线 | 欧美自拍一区 | 一区二区三区 | av一级毛片 | 伊人二区 | 国产一区二区三区在线免费 | 一区二区三区精品视频 | 久久精品亚洲精品 | 欧美成人黄色 | 国产精品久久久久久久久久久久久 | 日本中文字幕一区 | 久草福利在线视频 | 色视频www在线播放国产人成 | 日韩影院在线 | 国内精品视频 | 激情欧美日韩一区二区 | 粉嫩欧美一区二区三区高清影视 | 成人中文字幕在线观看 | 伊人在线 | 中文字幕在线免费播放 | 日韩欧美国产精品综合嫩v 日韩a∨精品日韩在线观看 |