日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode 755. 倒水(模拟)

發布時間:2024/7/5 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode 755. 倒水(模拟) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

    • 1. 題目
    • 2. 解題

1. 題目

給出一個地形高度圖, heights[i] 表示該索引處的高度。
每個索引的寬度為 1。在 V 個單位的水落在索引 K 處以后,每個索引位置有多少水?

水最先會在索引 K 處下降并且落在該索引位置的最高地形或水面之上。然后按如下方式流動:

  • 如果液滴最終可以通過向左流動而下降,則向左流動。
  • 否則,如果液滴最終可以通過向右流動而下降,則向右流動。
  • 否則,在當前的位置上升。
  • 這里,“最終下降” 的意思是液滴如果按此方向移動的話,最終可以下降到一個較低的水平。而且,“水平”的意思是當前列的地形的高度加上水的高度。

我們可以假定在數組兩側的邊界外有無限高的地形。而且,不能有部分水在多于 1 個的網格塊上均勻分布 - 每個單位的水必須要位于一個塊中。

示例 1: 輸入:heights = [2,1,1,2,1,2,2], V = 4, K = 3 輸出:[2,2,2,3,2,2,2] 解釋: # # # # ## # ### #########0123456 <- 索引第一個水滴降落在索引 K = 3 上:# # # w # ## # ### #########0123456 當向左或向右移動時,水可以移動到相同或更低的高度。When moving left or right, the water can only move to the same level or a lower level. (從水平上看,意思是該列的地形高度加上水的高度) 由于向左移動可以最終下落,因此向左移動。 (一個水滴 “下落” 的意思是可以相比之前可以進入更低的高度)# # # # ## w# ### #########0123456 由于向左移動不會使其降落,所以停在該位置上。下一個水滴下落:# # # w # ## w# ### #########0123456 由于新水滴向左移動可以最終下落,因此向左移動。 注意水滴仍然是優先選擇向左移動, 盡管可以向右移動(而且向右移動可以下落更快)# # # w # ## w# ### #########0123456 # # # # ##ww# ### #########0123456 經過剛才的階段后,第三個水滴下落。 由于向左移動不會最終下落,因此嘗試向右移動。 由于向右移動可以最終下落,因此向右移動。# # # w # ##ww# ### #########0123456 # # # # ##ww#w### #########0123456 最終,第四個水滴下落。 由于向左移動不會最終下落,因此嘗試向右移動。 由于向右移動不會最終下落,因此停在當前位置:# # # w # ##ww#w### #########0123456 最終的答案為 [2,2,2,3,2,2,2]:# ####### ####### 0123456 示例 2: 輸入:heights = [1,2,3,4], V = 2, K = 2 輸出:[2,3,3,4] 解釋: 最后的水滴落在索引 1 位置,因為繼續向左移動不會使其下降到更低的高度。示例 3: 輸入:heights = [3,1,3], V = 5, K = 1 輸出:[4,4,4]注: heights 的長度為 [1, 100] ,并且每個數的范圍為[0, 99]。 V 的范圍 [0, 2000]。 K 的范圍 [0, heights.length - 1]

來源:力扣(LeetCode) 鏈接:https://leetcode-cn.com/problems/pour-water
著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。

2. 解題

class Solution { public:vector<int> pourWater(vector<int>& heights, int V, int K) {int l = K, r = K, n = heights.size();while(V)//還有水{l = K;while(l >= 1 && heights[l-1] <= heights[l])//左邊有更低的l--;while(l < K && heights[l] == heights[l+1])//一樣高,靠近k處l++;if(l != K){heights[l]++;V--;continue;}r = K;while(r <= n-2 && heights[r] >= heights[r+1])//右邊有更低的r++;while(r > K && heights[r-1] == heights[r])r--;heights[r]++;//r==K的情況合并了V--;}return heights;} };

4 ms 7.2 MB


我的CSDN博客地址 https://michael.blog.csdn.net/

長按或掃碼關注我的公眾號(Michael阿明),一起加油、一起學習進步!

總結

以上是生活随笔為你收集整理的LeetCode 755. 倒水(模拟)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。