Karat - Koleksi

Pustaka koleksi standar Rust menyediakan implementasi yang efisien dari struktur data pemrograman tujuan umum yang paling umum. Bab ini membahas implementasi dari koleksi yang umum digunakan - Vektor, HashMap dan HashSet.

Vektor

Vektor adalah larik yang dapat diubah ukurannya. Ini menyimpan nilai dalam blok memori yang berdekatan. Struktur yang telah ditentukan Vec dapat digunakan untuk membuat vektor. Beberapa fitur penting dari Vector adalah -

  • Vektor dapat tumbuh atau menyusut saat runtime.

  • Vektor adalah kumpulan yang homogen.

  • Vektor menyimpan data sebagai urutan elemen dalam urutan tertentu. Setiap elemen dalam Vektor diberi nomor indeks unik. Indeks dimulai dari 0 dan naik ke n-1 di mana, n adalah ukuran koleksi. Misalnya, dalam kumpulan 5 elemen, elemen pertama akan berada di indeks 0 dan elemen terakhir akan berada di indeks 4.

  • Vektor hanya akan menambahkan nilai ke (atau mendekati) akhir. Dengan kata lain, Vektor dapat digunakan untuk mengimplementasikan tumpukan.

  • Memori untuk Vektor dialokasikan di heap.

Sintaks - Membuat Vektor

let mut instance_name = Vec::new();

Metode statis new () dari struktur Vec digunakan untuk membuat instance vektor.

Sebagai alternatif, vektor juga dapat dibuat menggunakan vec! makro. Sintaksnya seperti yang diberikan di bawah ini -

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

Tabel berikut mencantumkan beberapa fungsi struktur Vec yang umum digunakan.

Sr Tidak metode Tanda Tangan & Deskripsi
1 baru()

pub fn new()->Vect

Membangun Vec baru yang kosong. Vektor tidak akan dialokasikan sampai elemen didorong ke atasnya.

2 Dorong()

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

Menambahkan elemen ke belakang koleksi.

3 menghapus()

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

Menghapus dan mengembalikan elemen pada indeks posisi dalam vektor, menggeser semua elemen setelahnya ke kiri.

4 mengandung()

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

Mengembalikan nilai benar jika irisan berisi elemen dengan nilai yang diberikan.

5 len ()

pub fn len(&self) -> usize

Mengembalikan jumlah elemen dalam vektor, juga disebut sebagai 'panjangnya'.

Ilustrasi: Membuat Vektor - new ()

Untuk membuat vektor, kami menggunakan metode statis new -

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);
}

Contoh di atas membuat Vektor menggunakan metode statis new () yang didefinisikan dalam struktur Vec . Fungsi push (val) menambahkan nilai yang diteruskan sebagai parameter ke koleksi. Fungsi len () mengembalikan panjang vektor.

Keluaran

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

Ilustrasi: Membuat Vektor - vec! Makro

Kode berikut membuat vektor menggunakan vec! makro. Tipe data dari vektor disimpulkan nilai pertama yang ditugaskan padanya.

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

Keluaran

[1, 2, 3]

Seperti yang disebutkan sebelumnya, vektor hanya dapat berisi nilai dengan tipe data yang sama. Cuplikan berikut akan menampilkan error [E0308]: error mismatched types .

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

Ilustrasi: push ()

Menambahkan elemen ke akhir koleksi.

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

Keluaran

[20, 30, 40]

Ilustrasi: hapus ()

Menghapus dan mengembalikan elemen pada indeks posisi dalam vektor, menggeser semua elemen setelahnya ke kiri.

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

Keluaran

[10, 30]

Ilustrasi - berisi ()

Mengembalikan nilai true jika irisan berisi elemen dengan nilai yang diberikan -

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

Keluaran

found 10
[10, 20, 30]

Ilustrasi: len ()

Mengembalikan jumlah elemen dalam vektor, juga disebut sebagai 'panjangnya'.

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

Keluaran

size of vector is :3

Mengakses nilai dari Vektor

Elemen individu dalam vektor dapat diakses menggunakan nomor indeks yang sesuai. Contoh berikut membuat iklan vektor mencetak nilai elemen pertama.

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

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

Nilai dalam vektor juga bisa diambil menggunakan referensi ke koleksi.

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);
}

Keluaran

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

HashMap

Peta adalah kumpulan pasangan nilai kunci (disebut entri). Tidak ada dua entri di peta yang dapat memiliki kunci yang sama. Singkatnya, peta adalah tabel pencarian. HashMap menyimpan kunci dan nilai dalam tabel hash. Entri disimpan dalam urutan sewenang-wenang. Kuncinya digunakan untuk mencari nilai di HashMap. Struktur HashMap ditentukan di filestd::collectionsmodul. Modul ini harus diimpor secara eksplisit untuk mengakses struktur HashMap.

Sintaks: Membuat HashMap

let mut instance_name = HashMap::new();

Metode statis new () dari struktur HashMap digunakan untuk membuat objek HashMap. Metode ini membuat HashMap kosong.

Fungsi HashMap yang umum digunakan dibahas di bawah ini -

Sr Tidak metode Tanda Tangan & Deskripsi
1 memasukkan()

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

Menyisipkan pasangan kunci / nilai, jika tidak ada kunci maka Tidak ada yang dikembalikan. Setelah pembaruan, nilai lama dikembalikan.

2 len ()

pub fn len(&self) -> usize

Mengembalikan jumlah elemen di peta.

3 Dapatkan()

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

Mengembalikan referensi ke nilai yang sesuai dengan kunci.

4 iter ()

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

Sebuah iterator yang mengunjungi semua pasangan nilai kunci dalam urutan arbitrer. Jenis elemen iterator adalah (& 'a K, &' a V).

5 berisi_key

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

Mengembalikan nilai benar jika peta berisi nilai untuk kunci yang ditentukan.

6 menghapus()

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

Menghapus kunci dari peta, mengembalikan kunci dan nilai yang disimpan jika kunci tersebut sebelumnya ada di peta.

Ilustrasi: insert ()

Menyisipkan pasangan kunci / nilai ke dalam HashMap.

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

Program di atas membuat HashMap dan menginisialisasinya dengan 2 pasangan nilai kunci.

Keluaran

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

Ilustrasi: len ()

Mengembalikan jumlah elemen di peta

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());
}

Contoh di atas membuat HashMap dan mencetak jumlah total elemen di dalamnya.

Keluaran

size of map is 2

Ilustrasi - get ()

Mengembalikan referensi ke nilai yang sesuai dengan kunci. Contoh berikut mengambil nilai untuk kunci KL di HashMap.

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");
      }
   }
}

Keluaran

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

Ilustrasi - iter ()

Menampilkan iterator yang berisi referensi ke semua pasangan nilai kunci dalam urutan arbitrer.

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);
   }
}

Keluaran

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

Ilustrasi: contains_key ()

Mengembalikan nilai benar jika peta berisi nilai untuk kunci yang ditentukan.

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");
   }
}

Keluaran

found key

Ilustrasi: hapus ()

Menghapus kunci dari peta.

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());
}

Keluaran

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

HashSet

HashSet adalah sekumpulan nilai unik tipe T. Menambah dan menghapus nilai itu cepat, dan cepat untuk menanyakan apakah nilai yang diberikan ada di himpunan atau tidak. Struktur HashSet didefinisikan dalam modul std :: collections. Modul ini harus diimpor secara eksplisit untuk mengakses struktur HashSet.

Sintaks: Membuat HashSet

let mut hash_set_name = HashSet::new();

Metode statis, baru , dari struktur HashSet digunakan untuk membuat HashSet. Metode ini membuat HashSet kosong.

Tabel berikut mencantumkan beberapa metode struktur HashSet yang umum digunakan.

Sr Tidak metode Tanda Tangan & Deskripsi
1 memasukkan()

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

Menambahkan nilai ke set. Jika himpunan tidak memiliki nilai ini, true dikembalikan jika tidak salah.

2 len ()

pub fn len(&self) -> usize

Mengembalikan jumlah elemen dalam set.

3 Dapatkan()

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

Mengembalikan referensi ke nilai dalam himpunan, jika ada yang sama dengan nilai yang diberikan.

4 iter ()

pub fn iter(&self) -> Iter

Menampilkan iterator yang mengunjungi semua elemen dalam urutan arbitrer. Jenis elemen iterator adalah & 'a T.

5 berisi_key

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

Mengembalikan nilai benar jika set berisi nilai.

6 menghapus()

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

Menghapus nilai dari himpunan. Mengembalikan nilai benar jika nilainya ada di set.

Ilustrasi - masukkan ()

Menambahkan nilai ke set. HashSet tidak menambahkan nilai duplikat ke koleksi.

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);
}

Keluaran

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

Ilustrasi: len ()

Mengembalikan jumlah elemen dalam set.

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());
}

Keluaran

size of the set is 3

Ilustrasi - iter ()

Menjalankan kembali iterator yang mengunjungi semua elemen dalam urutan arbitrer.

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);
   }
}

Keluaran

TutorialsPoint
Mohtashim
Kannan

Ilustrasi: get ()

Mengembalikan referensi ke nilai dalam himpunan, jika ada, yang sama dengan nilai yang diberikan.

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);
}

Keluaran

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

Ilustrasi - berisi ()

Mengembalikan nilai benar jika set berisi nilai.

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");
   }  
}

Keluaran

found name

Ilustrasi: hapus ()

Menghapus nilai dari himpunan.

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());
}

Keluaran

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