接雨水(C语言)

题目链接:. - 力扣(LeetCode)

首先我们要明白要形成容器,接雨水

需要右边的柱子高于本身,并且需保证左方有高于本身的柱子

也就是这样,才会形成容器

这道题的解法之一是单调栈,并且需保证是递减的,才能形成容器

下面有代码解析:

typedef struct Stack

{

    //int val;

    int* arr;

    int size;

}ST;

void StackInit(ST* obj )

{

    obj->arr = (int*)malloc(sizeof(int)*20005);//创建一个数组,存下标,这个数值于题目给的数组大小有关

    obj->size = 0;

}

bool StackIsEmpty( ST* obj )

{

    return obj->size == 0 ;

}

int StackTop( ST* obj )

{

    return obj->arr[obj->size-1];

}

int StackPop(ST* obj)

{

    int i = 0;

    i = obj->arr[obj->size-1];

    obj->size--;

    return i;

}

void StackPush( ST* obj , int pi)

{

    obj->arr[obj->size++] = pi;

}

int trap(int* height, int heightSize) {

    ST obj;

    StackInit(&obj);

    int ans = 0;

    for( int i = 0 ; i < heightSize ; i++)

    {   

        while( !StackIsEmpty(&obj) && height[StackTop(&obj)] < height[i] )

   // 这里是为了保证第一个元素进栈,和当栈里为空时跳出

              //  例如:0 1 0 2 第一个元素进栈  然后 1 大于 0  , 0 被弹出 ,栈为空 , 此时不可能形成容器 ,1 就进栈 ,也可以这样写

//在外面让第一个元素进栈,栈为空时,break

       

        {

            int k = StackPop(&obj);

            while( !StackIsEmpty(&obj) && height[StackTop(&obj)] == height[k] )

            {  //这里是为了弹出相同元素 2  1    1   1    5  就要弹出 所有1

                StackPop(&obj);

            }

            if( !StackIsEmpty(&obj) ) // 此时形成容器

            {

                int top = StackTop(&obj);

                ans += (fmin(height[i],height[top]) - height[k])*(i - top - 1 );

            }                 //   高                                                              宽

        }

        StackPush(&obj,i);

    }

    return ans;

}

相关推荐

  1. 【困难】42. 雨水

    2024-04-01 05:24:04       54 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-01 05:24:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-01 05:24:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-01 05:24:04       87 阅读
  4. Python语言-面向对象

    2024-04-01 05:24:04       96 阅读

热门阅读

  1. 算法打卡day22

    2024-04-01 05:24:04       38 阅读
  2. qtcreator msvc编译器 链接外部库的方式

    2024-04-01 05:24:04       41 阅读
  3. MATLAB实现在LSB低三位嵌入图像

    2024-04-01 05:24:04       37 阅读
  4. 小程序归类及适合企业运用

    2024-04-01 05:24:04       39 阅读
  5. Web框架开发-Django信号

    2024-04-01 05:24:04       31 阅读
  6. 2023年C++语言B组蓝桥杯的三道题解【题解整合】

    2024-04-01 05:24:04       34 阅读
  7. 探索ChatGPT在学术论文写作中的应用方法

    2024-04-01 05:24:04       38 阅读
  8. ChatGPT:改变你的学术写作方式

    2024-04-01 05:24:04       42 阅读
  9. 100266. 交替子数组计数

    2024-04-01 05:24:04       39 阅读
  10. 蓝桥杯该如何准备

    2024-04-01 05:24:04       46 阅读
  11. 【Redis】多机部署Redis-sentinel

    2024-04-01 05:24:04       41 阅读
  12. Web框架开发-Django-extra过滤

    2024-04-01 05:24:04       34 阅读
  13. PostCSS深入解析:安装、配置与高效使用

    2024-04-01 05:24:04       51 阅读
  14. 2-Jquery层次选择器

    2024-04-01 05:24:04       40 阅读