677. 鍵值映射

677. 鍵值映射

實現一個 MapSum 類,支持兩個方法,insert?和?sum:

MapSum() 初始化 MapSum 對象
void insert(String key, int val) 插入 key-val 鍵值對,字符串表示鍵 key ,整數表示值 val 。如果鍵 key 已經存在,那么原來的鍵值對將被替代成新的鍵值對。
int sum(string prefix) 返回所有以該前綴 prefix 開頭的鍵 key 的值的總和。

示例:輸入:
["MapSum", "insert", "sum", "insert", "sum"]
[[], ["apple", 3], ["ap"], ["app", 2], ["ap"]]
輸出:
[null, null, 3, null, 5]解釋:
MapSum mapSum = new MapSum();
mapSum.insert("apple", 3);  
mapSum.sum("ap");           // return 3 (apple = 3)
mapSum.insert("app", 2);    
mapSum.sum("ap");           // return 5 (apple + app = 3 + 2 = 5)

提示:

  • 1 <= key.length, prefix.length <= 50
  • key 和 prefix 僅由小寫英文字母組成
  • 1 <= val <= 1000
  • 最多調用 50 次 insert 和 sum

解題思路

使用字典樹維護插入的鍵值對

  1. 新建Node類,用來構建字典樹,每個節點擁有26個子節點,對應26個字母,若某個節點為空,則代表不存在包含該字母的前綴。在每個節點中記錄,滿足當前節點前綴的總和的大小。

  2. 對于前綴 prefix 開頭的鍵 key 的值的總和的處理,每次在字典樹上插入節點的時候,我們都在插入路徑的每一個節點上增加val,而替換key值的時候,我們先正常插入key值,當發現key值已經被插入過了,就沿著插入路徑給每個節點減去val。

代碼

class Node {
public:Node* child[26] ;int sum,val;bool is_end;
};class MapSum {
public:Node *root;MapSum() {root=new Node();}void insert(string key, int val) {Node *cur = root;for (int i = 0; i < key.size(); ++i) {if (cur->child[key[i] - 'a'] == nullptr)cur->child[key[i] - 'a'] = new Node();cur = cur->child[key[i] - 'a'];if (cur != nullptr)(cur->sum) += val;}if (cur->is_end) {Node *new_cur = root;for (int i = 0; i < key.size(); ++i) {new_cur = new_cur->child[key[i] - 'a'];if (new_cur != nullptr)(new_cur->sum) -= cur->val;}}cur->is_end=true;cur->val = val;}int sum(string prefix) {Node *cur=root;int sum(0);int i = 0;for (; i < prefix.size()&&cur!= nullptr; ++i) {cur=cur->child[prefix[i]-'a'];if (cur!= nullptr)sum=cur->sum;}return cur!= nullptr?sum:0;}
};/*** Your MapSum object will be instantiated and called as such:* MapSum* obj = new MapSum();* obj->insert(key,val);* int param_2 = obj->sum(prefix);*/

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/389781.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/389781.shtml
英文地址,請注明出處:http://en.pswp.cn/news/389781.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

算法 從 數中選出_算法可以選出勝出的nba幻想選秀嗎

算法 從 數中選出Note from Towards Data Science’s editors: While we allow independent authors to publish articles in accordance with our rules and guidelines, we do not endorse each author’s contribution. You should not rely on an author’s works without …

jQuery表單校驗

小小Demo&#xff1a; <script>$(function () {//給username綁定失去焦點事件$("#username").blur(function () {//得到username文本框的值var nameValue $(this).val();//每次清除數據$("table font:first").remove();//校驗username是否合法if (n…

5912. 每一個查詢的最大美麗值

5912. 每一個查詢的最大美麗值 給你一個二維整數數組 items &#xff0c;其中 items[i] [pricei, beautyi] 分別表示每一個物品的 價格 和 美麗值 。 同時給你一個下標從 0 開始的整數數組 queries 。對于每個查詢 queries[j] &#xff0c;你想求出價格小于等于 queries[j] …

django-rest-framework第一次使用使用常見問題

2019獨角獸企業重金招聘Python工程師標準>>> 記錄在第一次使用django-rest-framework框架使用時遇到的問題&#xff0c;為了便于理解在這里創建了Person和Grade這兩個model from django.db import models class Person(models.Model):SHIRT_SIZES ((S, Small),(M, …

插入腳注把腳注標注刪掉_地獄司機不應該只是英國電影歷史數據中的腳注,這說明了為什么...

插入腳注把腳注標注刪掉Cowritten by Andie Yam由安迪(Andie Yam)撰寫 Hell Drivers”, 1957地獄司機 》電影海報 Data visualization is a great way to celebrate our favorite pieces of art as well as reveal connections and ideas that were previously invisible. Mor…

vue之axios 登陸驗證及數據獲取

登陸驗證&#xff0c;獲取token methods:{callApi () {var vm thisvm.msg vm.result //驗證地址vm.loginUrl http://xxx///查詢地址vm.apiUrl http://yyy/vm.loginModel {username: 你的用戶名,password: 你的密碼,// grant_type: password,}//先獲取 tokenaxios.post(v…

5926. 買票需要的時間

5926. 買票需要的時間 有 n 個人前來排隊買票&#xff0c;其中第 0 人站在隊伍 最前方 &#xff0c;第 (n - 1) 人站在隊伍 最后方 。 給你一個下標從 0 開始的整數數組 tickets &#xff0c;數組長度為 n &#xff0c;其中第 i 人想要購買的票數為 tickets[i] 。 每個人買票…

貝葉斯統計 傳統統計_統計貝葉斯如何補充常客

貝葉斯統計 傳統統計For many years, academics have been using so-called frequentist statistics to evaluate whether experimental manipulations have significant effects.多年以來&#xff0c;學者們一直在使用所謂的常客統計學來評估實驗操作是否具有significant效果。…

吳恩達機器學習+林軒田機器學習+高等數學和線性代數等視頻領取

機器學習一直是一個熱門的領域。這次小編應大家需求&#xff0c;整理了許多相關學習視頻和書籍。本次分享包含&#xff1a;臺灣大學林軒田老師的【機器學習基石】和【機器學習技法】視頻教學、吳恩達老師的機器學習分享、徐小湛的高等數學和線性代數視頻&#xff0c;還有相關機…

saltstack二

配置管理 haproxy的安裝部署 haproxy各版本安裝包下載路徑https://www.haproxy.org/download/1.6/src/&#xff0c;跳轉地址為http&#xff0c;改為https即可 創建相關目錄 # 創建配置目錄 [rootlinux-node1 ~]# mkdir /srv/salt/prod/pkg/ [rootlinux-node1 ~]# mkdir /srv/sa…

319. 燈泡開關

319. 燈泡開關 初始時有 n 個燈泡處于關閉狀態。第一輪&#xff0c;你將會打開所有燈泡。接下來的第二輪&#xff0c;你將會每兩個燈泡關閉一個。 第三輪&#xff0c;你每三個燈泡就切換一個燈泡的開關&#xff08;即&#xff0c;打開變關閉&#xff0c;關閉變打開&#xff0…

如何生成隨機不重復的11位數字

要求 不重復隨機11位數字不占存儲我們都知道11位數字(random)對應有最大值max和最小值min99999999999和10000000000.很簡單的從最小值開始按順序分發到最大值&#xff0c;就滿足了不重復&#xff0c;不占存儲&#xff0c;11位數字的特性。那么接下來就要考慮如何生成隨機數字這…

因為你的電腦安裝了即點即用_即你所愛

因為你的電腦安裝了即點即用Data visualization is a great way to celebrate our favorite pieces of art as well as reveal connections and ideas that were previously invisible. More importantly, it’s a fun way to connect things we love — visualizing data and …

關于前端緩存問題

Cookie、localStorage、sessionStorage的異同 之前沒怎接觸過前端緩存&#xff0c;請教了前端同事之后他給我粘了幾行代碼&#xff0c;用localStorage存取信息&#xff0c;后來老大review代碼的時候發現&#xff0c;被批了一頓&#xff0c;現在好好看看這幾個前端緩存的區別&am…

2074. 反轉偶數長度組的節點

2074. 反轉偶數長度組的節點 給你一個鏈表的頭節點 head 。 鏈表中的節點 按順序 劃分成若干 非空 組&#xff0c;這些非空組的長度構成一個自然數序列&#xff08;1, 2, 3, 4, …&#xff09;。一個組的 長度 就是組中分配到的節點數目。換句話說&#xff1a; 節點 1 分配給…

阿里云云服務器硬盤分區及掛載

云服務器環境&#xff1a;CentOS 6.2 64位 客戶端環境&#xff1a;Mac OSX 遠程連接方式&#xff1a;運行 Terminal&#xff0c;輸入命令 ssh usernameip 硬盤分區及掛載操作步驟&#xff1a; 查看未掛載的硬盤&#xff08;名稱為/dev/xvdb&#xff09;fdisk -l Disk /dev/xvdb…

團隊管理新思考_需要一個新的空間來思考討論和行動

團隊管理新思考andrew wong安德魯黃 Follow跟隨 Sep 4 九月4 There is a need for a new space to think, discuss, and act. This need are being felt by the majority of AI / ML / Data Product Managers out there. They are exhausted by the ever increasing data volum…

Uva201

原題地址&#xff1a;https://uva.onlinejudge.org/index.php?optioncom_onlinejudge&Itemid9 題意&#xff1a; 就是要你輸入一系列橫邊的起始點&#xff0c;和豎邊的起始點&#xff0c;然后你去找出這些邊里面構成的所有正方形。 心得體會 一道難度適中的模擬題&#xf…

2075. 解碼斜向換位密碼

2075. 解碼斜向換位密碼 字符串 originalText 使用 斜向換位密碼 &#xff0c;經由 行數固定 為 rows 的矩陣輔助&#xff0c;加密得到一個字符串 encodedText 。 originalText 先按從左上到右下的方式放置到矩陣中。 先填充藍色單元格&#xff0c;接著是紅色單元格&#xff…

微服務實戰(六):落地微服務架構到直銷系統(事件存儲)

在CQRS架構中&#xff0c;一個比較重要的內容就是當命令處理器從命令隊列中接收到相關的命令數據后&#xff0c;通過調用領域對象邏輯&#xff0c;然后將當前事件的對象數據持久化到事件存儲中。主要的用途是能夠快速持久化對象此次的狀態&#xff0c;另外也可以通過未來最終一…