接雨水(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;

}

相关推荐
双叶8364 分钟前
(C语言)超市管理系统 (正式版)(指针)(数据结构)(清屏操作)(文件读写)
c语言·开发语言·数据结构·c++·windows
序属秋秋秋30 分钟前
《数据结构初阶》【二叉树 精选9道OJ练习】
c语言·数据结构·c++·算法·leetcode
Tiny番茄33 分钟前
LeetCode 235. 二叉搜索树的最近公共祖先 LeetCode 701.二叉搜索树中的插入操作 LeetCode 450.删除二叉搜索树中的节点
数据结构·算法·leetcode
欧先生^_^2 小时前
rust语言,与c,go语言一样也是编译成二进制文件吗?
c语言·golang·rust
再睡一夏就好3 小时前
从硬件角度理解“Linux下一切皆文件“,详解用户级缓冲区
linux·服务器·c语言·开发语言·学习笔记
S01d13r7 小时前
LeetCode 解题思路 48(编辑距离、只出现一次的数字)
算法·leetcode·职场和发展
C_Liu_7 小时前
C语言:深入理解指针(5)
java·c语言·算法
small_wh1te_coder7 小时前
从经典力扣题发掘DFS与记忆化搜索的本质 -从矩阵最长递增路径入手 一步步探究dfs思维优化与编程深度思考
c语言·数据结构·c++·stm32·算法·leetcode·深度优先
枫景Maple7 小时前
LeetCode 45. 跳跃游戏 II(中等)
算法·leetcode
এ᭄画画的北北7 小时前
力扣-236.二叉树的最近公共祖先
算法·leetcode