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