जंग - संग्रह

रस्ट का मानक संग्रह पुस्तकालय सबसे आम सामान्य प्रयोजन प्रोग्रामिंग डेटा संरचनाओं का कुशल कार्यान्वयन प्रदान करता है। इस अध्याय में आमतौर पर उपयोग किए जाने वाले संग्रहों के कार्यान्वयन पर चर्चा की गई है - वेक्टर, हैशपैप और हैशसेट।

वेक्टर

एक वेक्टर एक resizable सरणी है। यह सन्निहित मेमोरी ब्लॉकों में मूल्यों को संग्रहीत करता है। वैक्टर बनाने के लिए पूर्वनिर्धारित संरचना Vec का उपयोग किया जा सकता है। एक वेक्टर की कुछ महत्वपूर्ण विशेषताएं हैं -

  • एक वेक्टर रनटाइम पर बढ़ या सिकुड़ सकता है।

  • एक वेक्टर एक सजातीय संग्रह है।

  • एक वेक्टर एक विशेष क्रम में तत्वों के अनुक्रम के रूप में डेटा संग्रहीत करता है। वेक्टर में प्रत्येक तत्व को एक अद्वितीय सूचकांक संख्या दी गई है। सूचकांक 0 से शुरू होता है और n-1 तक जाता है जहां, n संग्रह का आकार है। उदाहरण के लिए, 5 तत्वों के संग्रह में, पहला तत्व सूचकांक 0 पर होगा और अंतिम तत्व 4 सूचकांक पर होगा।

  • एक वेक्टर केवल (या पास) के अंत में मूल्यों को जोड़ देगा। दूसरे शब्दों में, स्टैक को लागू करने के लिए एक वेक्टर का उपयोग किया जा सकता है।

  • एक वेक्टर के लिए मेमोरी ढेर में आवंटित की जाती है।

सिंटेक्स - एक वेक्टर बनाना

let mut instance_name = Vec::new();

Vec संरचना की स्थिर विधि नई () का उपयोग वेक्टर उदाहरण बनाने के लिए किया जाता है।

वैकल्पिक रूप से, वेक्टर का उपयोग करके एक वेक्टर भी बनाया जा सकता है! मैक्रो। सिंटैक्स नीचे दिया गया है -

let vector_name = vec![val1,val2,val3]

निम्न तालिका Vec संरचना के कुछ सामान्यतः उपयोग किए जाने वाले कार्यों को सूचीबद्ध करती है।

अनु क्रमांक तरीका हस्ताक्षर और विवरण
1 नया()

pub fn new()->Vect

एक नया, खाली वीईसी का निर्माण करता है। जब तक तत्वों को उस पर धकेल नहीं दिया जाएगा तब तक वेक्टर आवंटित नहीं होगा।

2 धक्का दें()

pub fn push(&mut self, value: T)

एक संग्रह के पीछे एक तत्व जोड़ता है।

3 हटाना()

pub fn remove(&mut self, index: usize) -> T

वेक्टर के भीतर स्थिति सूचकांक में तत्व को निकालता है और छोड़ता है, इसके बाद सभी तत्वों को बाईं ओर स्थानांतरित करता है।

4 शामिल ()

pub fn contains(&self, x: &T) -> bool

सही है अगर टुकड़ा में दिए गए मान के साथ एक तत्व होता है।

5 लेन ()

pub fn len(&self) -> usize

वेक्टर में तत्वों की संख्या लौटाता है, जिसे इसकी 'लंबाई' भी कहा जाता है।

चित्रण: एक वेक्टर बनाना - नया ()

एक सदिश बनाने के लिए, हम स्थिर विधि का उपयोग नई -

fn main() {
   let mut v = Vec::new();
   v.push(20);
   v.push(30);
   v.push(40);

   println!("size of vector is :{}",v.len());
   println!("{:?}",v);
}

उपर्युक्त उदाहरण स्टैटिक मेथड न्यू () का उपयोग करके एक वेक्टर बनाता है जिसे संरचना Vec में परिभाषित किया गया है । धक्का (वैल) समारोह संग्रह करने के लिए पैरामीटर के रूप में पारित कर दिया मूल्य जोड़ देता है। लेन () फ़ंक्शन वेक्टर की लंबाई लौटाता है।

उत्पादन

size of vector is :3
[20, 30, 40]

चित्रण: वेक्टर बनाना - vec! मैक्रो

निम्न कोड vec का उपयोग करके एक वेक्टर बनाता है! मैक्रो। वेक्टर का डेटा प्रकार पहला मान है जो इसे सौंपा गया है।

fn main() {
   let v = vec![1,2,3];
   println!("{:?}",v);
}

उत्पादन

[1, 2, 3]

जैसा कि पहले उल्लेख किया गया है, एक वेक्टर में केवल समान डेटा प्रकार के मान हो सकते हैं। निम्न स्निपेट एक त्रुटि फेंक देगा [E0308]: बेमेल प्रकार की त्रुटि।

fn main() {
   let v = vec![1,2,3,"hello"];
   println!("{:?}",v);
}

चित्रण: धक्का ()

एक संग्रह के अंत में एक तत्व जोड़ता है।

fn main() {
   let mut v = Vec::new();
   v.push(20);
   v.push(30);
   v.push(40);
   
   println!("{:?}",v);
}

उत्पादन

[20, 30, 40]

चित्रण: हटाएं ()

वेक्टर के भीतर स्थिति सूचकांक में तत्व को निकालता है और छोड़ता है, इसके बाद सभी तत्वों को बाईं ओर स्थानांतरित करता है।

fn main() {
   let mut v = vec![10,20,30];
   v.remove(1);
   println!("{:?}",v);
}

उत्पादन

[10, 30]

चित्रण - शामिल ()

सही है अगर टुकड़ा में दिए गए मान के साथ एक तत्व है -

fn main() {
   let v = vec![10,20,30];
   if v.contains(&10) {
      println!("found 10");
   }
   println!("{:?}",v);
}

उत्पादन

found 10
[10, 20, 30]

चित्रण: लेन ()

वेक्टर में तत्वों की संख्या लौटाता है, जिसे इसकी 'लंबाई' भी कहा जाता है।

fn main() {
   let v = vec![1,2,3];
   println!("size of vector is :{}",v.len());
}

उत्पादन

size of vector is :3

एक वेक्टर से मानों तक पहुंचना

एक वेक्टर में अलग-अलग तत्वों को उनके संबंधित इंडेक्स नंबरों का उपयोग करके एक्सेस किया जा सकता है। निम्नलिखित उदाहरण एक वेक्टर विज्ञापन बनाता है जो पहले तत्व के मूल्य को प्रिंट करता है।

fn main() {
   let mut v = Vec::new();
   v.push(20);
   v.push(30);

   println!("{:?}",v[0]);
}
Output: `20`

एक सदिश में मान भी संग्रह के संदर्भ का उपयोग करके प्राप्त किया जा सकता है।

fn main() {
   let mut v = Vec::new();
   v.push(20);
   v.push(30);
   v.push(40);
   v.push(500);

   for i in &v {
      println!("{}",i);
   }
   println!("{:?}",v);
}

उत्पादन

20
30
40
500
[20, 30, 40, 500]

हैश मैप

एक मानचित्र कुंजी-मूल्य जोड़े (प्रविष्टियों कहा जाता है) का एक संग्रह है। मानचित्र में कोई भी दो प्रविष्टियाँ समान कुंजी नहीं रख सकती हैं। संक्षेप में, एक नक्शा एक लुकअप टेबल है। एक हैशपैड एक हैश तालिका में कुंजियों और मूल्यों को संग्रहीत करता है। प्रविष्टियों को एक अनियंत्रित क्रम में संग्रहीत किया जाता है। कुंजी का उपयोग हाशप में मानों को खोजने के लिए किया जाता है। हाशपा संरचना में परिभाषित किया गया हैstd::collectionsमापांक। इस मॉड्यूल को HashMap संरचना तक पहुंचने के लिए स्पष्ट रूप से आयात किया जाना चाहिए।

सिंटेक्स: एक हैशमैप बनाना

let mut instance_name = HashMap::new();

HashMap संरचना की स्थिर विधि नई () का उपयोग HashMap ऑब्जेक्ट बनाने के लिए किया जाता है। यह विधि एक खाली HashMap बनाता है।

हाशप के आमतौर पर उपयोग किए जाने वाले कार्यों की चर्चा नीचे दी गई है -

अनु क्रमांक तरीका हस्ताक्षर और विवरण
1 डालने ()

pub fn insert(&mut self, k: K, v: V) -> Option

एक कुंजी / मूल्य जोड़ी सम्मिलित करता है, यदि कोई कुंजी नहीं है तो कोई भी वापस नहीं किया जाता है। अद्यतन करने के बाद, पुराना मान वापस कर दिया जाता है।

2 लेन ()

pub fn len(&self) -> usize

नक्शे में तत्वों की संख्या लौटाता है।

3 प्राप्त()

pub fn get<Q: ?Sized>(&lself, k: &Q) -> Option<&V> where K:Borrow Q:Hash+ Eq

कुंजी के अनुरूप मान का संदर्भ देता है।

4 आईटीईआर ()

pub fn iter(&self) -> Iter<K, V>

एक पुनरावृत्त व्यक्ति सभी प्रमुख-मूल्य जोड़े का मनमाना क्रम में दौरा करता है। इटरेटर तत्व प्रकार (& a K, & 'a V) है।

5 contains_key

pub fn contains_key<Q: ?Sized>(&self, k: &Q) -> bool

यदि मानचित्र में निर्दिष्ट कुंजी के लिए मान है तो यह सही है।

6 हटाना()

pub fn remove_entry<Q: ?Sized>(&mut self, k: &Q) -> Option<(K, V)>

यदि नक्शे में कुंजी पहले थी, तो संग्रहीत कुंजी और मान लौटाते हुए मानचित्र से एक कुंजी निकालता है।

चित्रण: सम्मिलित करें ()

हाशपैप में एक कुंजी / मान युग्म सम्मिलित करता है।

use std::collections::HashMap;
fn main(){
   let mut stateCodes = HashMap::new();
   stateCodes.insert("KL","Kerala");
   stateCodes.insert("MH","Maharashtra");
   println!("{:?}",stateCodes);
}

उपरोक्त कार्यक्रम एक HashMap बनाता है और इसे 2 कुंजी-मूल्य जोड़े के साथ आरंभ करता है।

उत्पादन

{"KL": "Kerala", "MH": "Maharashtra"}

चित्रण: लेन ()

नक्शे में तत्वों की संख्या लौटाता है

use std::collections::HashMap;
fn main() {
   let mut stateCodes = HashMap::new();
   stateCodes.insert("KL","Kerala");
   stateCodes.insert("MH","Maharashtra");
   println!("size of map is {}",stateCodes.len());
}

उपरोक्त उदाहरण एक HashMap बनाता है और इसमें कुल तत्वों को प्रिंट करता है।

उत्पादन

size of map is 2

चित्रण - प्राप्त ()

कुंजी के अनुरूप मान का संदर्भ देता है। निम्नलिखित उदाहरण हाशप में कुंजी KL के लिए मान को पुनः प्राप्त करता है ।

use std::collections::HashMap;
fn main() {
   let mut stateCodes = HashMap::new();
   stateCodes.insert("KL","Kerala");
   stateCodes.insert("MH","Maharashtra");
   println!("size of map is {}",stateCodes.len());
   println!("{:?}",stateCodes);

   match stateCodes.get(&"KL") {
      Some(value)=> {
         println!("Value for key KL is {}",value);
      }
      None => {
         println!("nothing found");
      }
   }
}

उत्पादन

size of map is 2
{"KL": "Kerala", "MH": "Maharashtra"}
Value for key KL is Kerala

चित्रण - iter ()

मनमानी क्रम में सभी कुंजी-मूल्य जोड़े के संदर्भ में एक पुनरावृत्ति देता है।

use std::collections::HashMap;
fn main() {
   let mut stateCodes = HashMap::new();
   stateCodes.insert("KL","Kerala");
   stateCodes.insert("MH","Maharashtra");

   for (key, val) in stateCodes.iter() {
      println!("key: {} val: {}", key, val);
   }
}

उत्पादन

key: MH val: Maharashtra
key: KL val: Kerala

चित्रण: समाहित_की ()

यदि मानचित्र में निर्दिष्ट कुंजी के लिए मान है तो यह सही है।

use std::collections::HashMap;
fn main() {
   let mut stateCodes = HashMap::new();
   stateCodes.insert("KL","Kerala");
   stateCodes.insert("MH","Maharashtra");
   stateCodes.insert("GJ","Gujarat");

   if stateCodes.contains_key(&"GJ") {
      println!("found key");
   }
}

उत्पादन

found key

चित्रण: हटाएं ()

नक्शे से एक कुंजी निकालता है।

use std::collections::HashMap;
fn main() {
   let mut stateCodes = HashMap::new();
   stateCodes.insert("KL","Kerala");
   stateCodes.insert("MH","Maharashtra");
   stateCodes.insert("GJ","Gujarat");

   println!("length of the hashmap {}",stateCodes.len());
   stateCodes.remove(&"GJ");
   println!("length of the hashmap after remove() {}",stateCodes.len());
}

उत्पादन

length of the hashmap 3
length of the hashmap after remove() 2

HashSet

HashSet T के अद्वितीय मानों का एक समूह है। मानों को जोड़ना और हटाना तेजी से होता है, और यह पूछना तेजी से होता है कि कोई दिया गया मान सेट में है या नहीं। HashSet संरचना को std :: collection मॉड्यूल में परिभाषित किया गया है। इस मॉड्यूल को हैशसेट संरचना तक पहुंचने के लिए स्पष्ट रूप से आयात किया जाना चाहिए।

सिंटेक्स: एक हैशसेट बनाना

let mut hash_set_name = HashSet::new();

HashSet संरचना का नया , नया तरीका, HashSet बनाने के लिए उपयोग किया जाता है। यह विधि एक खाली HashSet बनाता है।

निम्न तालिका हैशसेट संरचना के कुछ सामान्यतः उपयोग किए गए तरीकों को सूचीबद्ध करती है।

अनु क्रमांक तरीका हस्ताक्षर और विवरण
1 डालने ()

pub fn insert(&mut self, value: T) -> bool

सेट के लिए एक मान जोड़ता है। यदि सेट में यह मान मौजूद नहीं है, तो सत्य को और गलत माना जाता है।

2 लेन ()

pub fn len(&self) -> usize

सेट में तत्वों की संख्या लौटाता है।

3 प्राप्त()

pub fn get<Q:?Sized>(&self, value: &Q) -> Option<&T> where T: Borrow,Q: Hash + Eq,

दिए गए मान के बराबर होने पर, सेट में दिए गए मान का संदर्भ देता है।

4 आईटीईआर ()

pub fn iter(&self) -> Iter

मनमानी क्रम में सभी तत्वों पर जाकर एक पुनरावृति देता है। इटरेटर तत्व प्रकार है & 'a T।

5 contains_key

pub fn contains<Q: ?Sized>(&self, value: &Q) -> bool

यदि सेट में कोई मान है तो यह सही है।

6 हटाना()

pub fn remove<Q: ?Sized>(&mut self, value: &Q) -> bool

सेट से एक मान निकालता है। यदि सेट में मान मौजूद था, तो वापस लौटाता है।

चित्रण - सम्मिलित करें ()

सेट के लिए एक मान जोड़ता है। HashSet संग्रह में डुप्लिकेट मान नहीं जोड़ता है।

use std::collections::HashSet;
fn main() {
   let mut names = HashSet::new();

   names.insert("Mohtashim");
   names.insert("Kannan");
   names.insert("TutorialsPoint");
   names.insert("Mohtashim");//duplicates not added

   println!("{:?}",names);
}

उत्पादन

{"TutorialsPoint", "Kannan", "Mohtashim"}

चित्रण: लेन ()

सेट में तत्वों की संख्या लौटाता है।

use std::collections::HashSet;
fn main() {
   let mut names = HashSet::new();
   names.insert("Mohtashim");
   names.insert("Kannan");
   names.insert("TutorialsPoint");
   println!("size of the set is {}",names.len());
}

उत्पादन

size of the set is 3

चित्रण - iter ()

मनमानी क्रम में सभी तत्वों का दौरा करने वाले एक पुनरावृत्तिकर्ता को हटा देता है।

use std::collections::HashSet;
fn main() {
   let mut names = HashSet::new();
   names.insert("Mohtashim");
   names.insert("Kannan");
   names.insert("TutorialsPoint");
   names.insert("Mohtashim");

   for name in names.iter() {
      println!("{}",name);
   }
}

उत्पादन

TutorialsPoint
Mohtashim
Kannan

चित्रण: प्राप्त ()

सेट में मान का संदर्भ देता है, यदि कोई हो, जो दिए गए मूल्य के बराबर है।

use std::collections::HashSet;
fn main() {
   let mut names = HashSet::new();
   names.insert("Mohtashim");
   names.insert("Kannan");
   names.insert("TutorialsPoint");
   names.insert("Mohtashim");

   match names.get(&"Mohtashim"){
      Some(value)=>{
         println!("found {}",value);
      }
      None =>{
         println!("not found");
      }
   }
   println!("{:?}",names);
}

उत्पादन

found Mohtashim
{"Kannan", "Mohtashim", "TutorialsPoint"}

चित्रण - शामिल ()

यदि सेट में कोई मान है तो यह सही है।

use std::collections::HashSet;

fn main() {
   let mut names = HashSet::new();
   names.insert("Mohtashim");
   names.insert("Kannan");
   names.insert("TutorialsPoint");

   if names.contains(&"Kannan") {
      println!("found name");
   }  
}

उत्पादन

found name

चित्रण: हटाएं ()

सेट से एक मान निकालता है।

use std::collections::HashSet;

fn main() {
   let mut names = HashSet::new();
   names.insert("Mohtashim");
   names.insert("Kannan");
   names.insert("TutorialsPoint");
   println!("length of the Hashset: {}",names.len());
   names.remove(&"Kannan");
   println!("length of the Hashset after remove() : {}",names.len());
}

उत्पादन

length of the Hashset: 3
length of the Hashset after remove() : 2