C++程式用於透過鍵更新字典的值
許多電腦語言都提供字典,這是一種資料結構。字典是一種更快的資料結構,它基於鍵和值來儲存資料。它保留了鍵值組合,以便鍵可以幾乎即時地輕鬆搜尋某些組件。 C STL 語言標準包括類似字典的資料結構。術語“map”用於描述這種資料結構。此映射會建立一對任意類型的鍵和值(由於我們使用的是 C ,因此必須在編譯之前定義類型)。本節將示範如何在 C 中更新已存在的對應或字典中的值。
我們先來看看地圖資料結構的定義。這些內部模板需要兩種不同的類型。下面顯示了語法和必要的函式庫 -
定義地圖資料結構的語法
#include <map> map<type1, type2=""> mapVariable; </type1,></map>
在這種情況下,我們必須導入「地圖」庫才能使用地圖資料結構。為此需要資料類型 1 和 2。 key參數的資料型別為type1,value參數的資料型別為type2。這裡從地圖類型類別派生的物件是mapVariable。現在讓我們看看如何使用 C 映射來獲取它。
在映射資料結構中,我們可以透過存取現有鍵或新鍵將值放入映射中。由於這裡我們討論的是更新值,因此我們必須更新現有的金鑰。鍵將像數組索引符號一樣用在方括號內。讓我們看看這個的語法 -
更新地圖內元素的語法
mapVariable [<the key="" value="">] = <the new="" value="">; </the></the>
演算法
已建立的字典或地圖 D
已有鍵值k
#新金鑰 k 的值 v
像 D[ k ] = v 一樣更新
返回D
#範例
#include <iostream> #include <map> using namespace std; void display( map <string, int>& givenMap ){ for ( auto& it : givenMap ) { cout << "Key: " << it.first << ", value: " << it.second << endl; } } int main(){ map<string, int> givenMap; givenMap = { { "ABCD", 25 }, { "EFGH", 50 }, { "IJKL", 75 }, { "MNOP", 100 }, { "QRST", 125 } }; cout << "Before updation: " << endl; display( givenMap ); cout << "After Updation: " << endl; //update the value of MNOP to 500 givenMap[ "MNOP" ] = 500; display( givenMap ); }
輸出
Before updation: Key: ABCD, value: 25 Key: EFGH, value: 50 Key: IJKL, value: 75 Key: MNOP, value: 100 Key: QRST, value: 125 After Updation: Key: ABCD, value: 25 Key: EFGH, value: 50 Key: IJKL, value: 75 Key: MNOP, value: 500 Key: QRST, value: 125
在此方法中,我們透過存取關鍵參數成功更新了值。然而,這個過程可能並不總是準確的。此過程有一個嚴重的缺點,即給定的鍵可能不存在於映射中。但透過使用此過程,它將插入具有給定值的新鍵。因此,在下一個方法中,我們將看到如何搜尋並在成功搜尋後更新元素。
搜尋後更新
可以使用地圖物件中的 find() 函數來檢查地圖中是否存在某個鍵。它將返回鍵的指針引用,否則,它將返回映射的“end()”指針,這表示映射不包含其中的元素。讓我們看看演算法和實現以便更好地理解。
演算法
已建立的字典或地圖 D
已有鍵值k
#新金鑰 k 的值 v
建立一個迭代器物件itr來取得鍵值對的指標
呼叫 find() 方法將字典 D 放入 itr
如果 itr 不是 D 的結尾,則表示金鑰存在,則
將 v 放入 itr
結束如果
範例
#include <iostream> #include <map> using namespace std; void display( map <string, int>& givenMap ){ for ( auto& it : givenMap ) { cout << "Key: " << it.first << ", value: " << it.second << endl; } } void updateElement( map <string, int>& givenMap, string givenKey, int newValue ){ map <string, int>::iterator itr; itr = givenMap.find( givenKey ); if( itr != givenMap.end() ){ // when item has found itr->second = newValue; } } int main(){ map<string, int> givenMap; givenMap = { { "ABCD", 25 }, { "EFGH", 50 }, { "IJKL", 75 }, { "MNOP", 100 }, { "QRST", 125 } }; cout << "Before updation: " << endl; display( givenMap ); cout << "After Updation: " << endl; //update the value of MNOP to 500 updateElement( givenMap, "MNOP", 1580 ); display( givenMap ); }
輸出
Before updation: Key: ABCD, value: 25 Key: EFGH, value: 50 Key: IJKL, value: 75 Key: MNOP, value: 100 Key: QRST, value: 125 After Updation: Key: ABCD, value: 25 Key: EFGH, value: 50 Key: IJKL, value: 75 Key: MNOP, value: 1580 Key: QRST, value: 125
在此方法中,updateElement函數將映射、現有鍵和 newValue 作為輸入。之後搜尋該密鑰。如果存在,則僅更新該值,否則只需從該函數中得出。因此,透過使用此方法,我們無法在地圖中建立新條目,而只能更新現有條目。
結論
在這篇文章中,我們了解如何使用鍵更新地圖中的元素。在第一種方法中,我們使用直接分配方法,該方法成功更新元素,但當鍵尚不存在時,它也可以添加新元素。第二種方法透過一開始的簡單搜尋消除了這個問題。有時我們可能會注意到第二種方法需要額外的時間來搜尋金鑰然後更新它。因此,與第一種方法相比,它需要更多的搜尋時間。但如果我們仔細思考,在第一種方法中,這項發現也本質上實現了。由於資料結構使用基於哈希的技術,因此它將在恆定時間內運行(在大多數情況下)。
以上是C++程式用於透過鍵更新字典的值的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

給出以下是一個將羅馬數字轉換為十進制數字的C語言演算法:演算法步驟1-開始步驟2-在運行時讀取羅馬數字步驟3-長度:=strlen(roman)步驟4-對於i=0到長度-1 步驟4.1-switch(roman[i]) 步驟4.1.1-case'm': &nbs

字典序字串比較是指字串依照字典順序進行比較。例如,如果有兩個字串'apple'和'appeal',第一個字串將排在後面,因為前三個字元'app'是相同的。然後對於第一個字串,字元是'l',而在第二個字串中,第四個字元是'e'。由於'e'比'l'短,所以如果我們按照字典順序排列,它將排在前面。在安排之前,字串會按字典順序進行比較。在本文中,我們將看到使用C++進行按字典順序比較兩個字串的不同技術。在C++字串中使用compare()函數C++string物件有一個compare()

連結列表使用動態記憶體分配,即它們相應地增長和收縮。它們被定義為節點的集合。這裡,節點有兩個部分,即資料和鏈路。資料、連結和鍊錶的表示如下-鍊錶的類型鍊錶有四種類型,如下:-單鍊錶/單鍊錶雙/雙向鍊錶循環單鍊錶循環雙鍊錶我們使用遞歸方法求鍊錶長度的邏輯是-intlength(node *temp){ if(temp==NULL) returnl; else{&n

rename函數將檔案或目錄從舊名稱變更為新名稱。此操作類似於移動操作。因此,我們也可以使用此rename函數來移動檔案。此函數存在於stdio.h庫頭檔中。 rename函數的語法如下:intrename(constchar*oldname,constchar*newname);rename()函數的函數它接受兩個參數。一個是oldname,一個是newname。這兩個參數都是指向常數字元的指針,用於定義檔案的舊名稱和新名稱。如果檔案重新命名成功,則傳回零;否則,傳回非零整數。在重新命名操作期間

雙曲函數是使用雙曲線而不是圓定義的,與普通三角函數相當。它從提供的弧度角傳回雙曲正弦函數中的比率參數。但要做相反的事,或者換句話說。如果我們想要根據雙曲正弦值計算角度,我們需要像雙曲反正弦運算一樣的反雙曲三角運算。本課程將示範如何使用C++中的雙曲反正弦(asinh)函數,並使用雙曲正弦值(以弧度為單位)計算角度。雙曲反正弦運算遵循下列公式-$$\mathrm{sinh^{-1}x\:=\:In(x\:+\:\sqrt{x^2\:+\:1})},其中\:In\:是\:自然對數\:(log_e\:k)

映射是C++中的一種特殊類型的容器,其中每個元素都是一對兩個值,即鍵值和映射值。鍵值用於索引每個項目,映射值是與鍵關聯的值。無論映射值是否唯一,鍵始終是唯一的。要在C++中列印映射元素,我們必須使用迭代器。一組項目中的一個元素由迭代器物件指示。迭代器主要與陣列和其他類型的容器(例如向量)一起使用,並且它們具有一組特定的操作,可用於識別特定範圍內的特定元素。可以增加或減少迭代器來引用範圍或容器中存在的不同元素。迭代器指向範圍內特定元素的記憶體位置。使用迭代器在C++中列印地圖首先,我們先來看看如何定義

現代科學在很大程度上依賴複數的概念,而這個概念最初是透過GirolamoCardano在16世紀引入的17世紀初建立。複數的公式是a+ib,其中a保留html代碼且b是實數。一個複數被認為有兩個部分:實部<a>和虛部(<ib>)。 i或iota的值為√-1。 C++中的複數類別是用來表示複數的類別。 C++中的complex類別可以表示並控制幾個複數操作。我們來看看如何表示和控制顯示複數。 imag()成員函數如前所述,複數由實部和虛部兩部分組成。顯示實部我們使用real()

在解決一些邏輯程式設計問題時,使用字串或字元有時非常有用。字串是字元的集合,字元是1位元組資料類型,用於保存ASCII值中的符號。符號可以是英文字母、數字或特殊字元。在本文中,我們將學習如何使用C++檢查一個字元是否是英文字母或字母表中的字母。檢查isalpha()函數要檢查數字是否為字母,我們可以使用ctype.h頭檔中的isalpha()函數。這將一個字元作為輸入,如果是字母表,則傳回true,否則傳回false。讓我們看看下面的C++實作來了解這個函數的用法。例子的中文翻譯為:示
