LeetCode 755. 倒水(模拟)
生活随笔
收集整理的這篇文章主要介紹了
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. 倒水(模拟)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LeetCode 1653. 使字符串平
- 下一篇: LeetCode 1569. 将子数组重