题解 | #接雨水问题#

接雨水问题

https://www.nowcoder.com/practice/31c1aed01b394f0b8b7734de0324e00f

基本思路:使用双指针向中间逼近即可
1.使用双指针
2.使用两个值记录下双指针的左右值,同时如果遇到比自己大,则必须更新当前值,用于计算结果
class Solution {
public:
    long long maxWater(vector<int>& arr) {
        // write code here
        //基本思路,就是两边开始,由低的往高处找,遇到比自己更高的就更新当前值,遇到比自己低的就
        //计算当前可以成的雨水数
        int size = arr.size();
        int left = 0;
        int right = size - 1;
        long long res = 0;//记录最后的结果,也即雨水值
        long long templ = arr[left];//记录左指针的值,指针会一直更新,但是templ必须要遇到更大的值才更新
        long long tempr = arr[right];//记录右指针的值
        
        //如果是遇到left刚好等于right- 1,此时不会影响最后的结果,所以这里用的是left < right - 1
        while(left < right - 1)
        {
            //当左边维护的值小于右边维护的值
            if(templ < tempr)
            {
                left++;//自加
                //如果left指针指向的值小于之前维护的值,则说明可以接到雨水
                if(arr[left] <= templ)
                {
                    res += (templ - arr[left]);
                }
                //接不到雨水,则更新自己的左值
                else{
                    templ = arr[left];
                }
                
            }
            else
            {
                right--;
                if(arr[right] <= tempr)
                {
                    res += (tempr - arr[right]);
                }
                else{
                    tempr = arr[right];
                }
            }
        }
        return res;
    }
};


全部评论

相关推荐

2025-12-23 16:48
深圳大学 前端工程师
点赞 评论 收藏
分享
2025-12-31 19:23
已编辑
门头沟学院 Java
ssob是已读不回的,字节是压根不敢投的,简历是反反复复改了N遍的,八股是永远背不完的😅😅😅扯远了,道心破碎了,把简历发出来让大伙先看看笑话。再说正事。寒假日常实习还是很难找,连个面试都难约,我不是个例,这是网上普遍反映。不报希望了,趁着2、3月前赶紧做些什么才是。扔几个碎碎念:1.这破简历还能怎么改?写到什么程度才能过实习岗筛选?广大牛友来锐评一下2.火速辅修go,是否可行目前看来是学习成本最小的。首先,很多go实习岗位已经明确要求掌握gin等技术栈,拿java简历投go的时代已经过去了。其次,很多后端的东西,MySQL、Redis这些都是通用的,不用重新学。所以这个问题就具体为:2.1&nbsp;java&amp;go混血简历怎么写第一个项目,仿大麦的微服务,不太好改。因为有用到Redisson、AOP、SpringAI这些java强相关的东西,包装成go需要替换这些方案。第二个,点评魔改。应该可以包装成go,github上也有人用go重写过。2.2&nbsp;java&amp;go通用的轮子RPC直接pass了,太烂大街了。不知道动态线程池能不能做。反正项目上新有风险,不一定来得及,非必要就不开新的项目。补充:别跟我扯RAG了,这玩意已经成新的烂大街了,详见我上一篇的吐槽。3.认真学微调prompt什么的这个半步踩进算法了已经。八股和场景题完全就是另一套,没两三个月搞不定的。约等于换方向
简历中的项目经历要怎么写
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务