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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

677. 键值映射

發(fā)布時間:2023/11/29 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 677. 键值映射 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

677. 鍵值映射

實現(xiàn)一個 MapSum 類,支持兩個方法,insert?和?sum:

MapSum() 初始化 MapSum 對象
void insert(String key, int val) 插入 key-val 鍵值對,字符串表示鍵 key ,整數(shù)表示值 val 。如果鍵 key 已經(jīng)存在,那么原來的鍵值對將被替代成新的鍵值對。
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
  • 最多調(diào)用 50 次 insert 和 sum

解題思路

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

  • 新建Node類,用來構(gòu)建字典樹,每個節(jié)點擁有26個子節(jié)點,對應(yīng)26個字母,若某個節(jié)點為空,則代表不存在包含該字母的前綴。在每個節(jié)點中記錄,滿足當(dāng)前節(jié)點前綴的總和的大小。

  • 對于前綴 prefix 開頭的鍵 key 的值的總和的處理,每次在字典樹上插入節(jié)點的時候,我們都在插入路徑的每一個節(jié)點上增加val,而替換key值的時候,我們先正常插入key值,當(dāng)發(fā)現(xiàn)key值已經(jīng)被插入過了,就沿著插入路徑給每個節(jié)點減去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);*/

    總結(jié)

    以上是生活随笔為你收集整理的677. 键值映射的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。