Rust Check Subset Function
Write a Rust function that takes two sets as input and returns true if the first set is a subset of the second set, otherwise returns false.
Sample Solution:
Rust Code:
use std::collections::HashSet; // Import the HashSet type from the standard library
// Define a function to check if the first set is a subset of the second set
fn is_subset(set1: &HashSet<i32>, set2: &HashSet<i32>) -> bool {
// Iterate over each element in the first set
for element in set1 {
// Check if the element is not present in the second set
if !set2.contains(element) {
// If any element of set1 is not found in set2, return false
return false;
}
}
// If all elements of set1 are found in set2, return true
true
}
fn main() {
// Create two sample sets
let set1: HashSet<i32> = vec![1, 2, 3].into_iter().collect();
let set2: HashSet<i32> = vec![1, 2, 3, 4, 5].into_iter().collect();
// Check if set1 is a subset of set2
let is_set1_subset_of_set2 = is_subset(&set1, &set2);
// Print the result
println!("Is set1 a subset of set2? {}", is_set1_subset_of_set2);
}
Output:
Is set1 a subset of set2? true
Explanation:
Here is a brief explanation of the above Rust code:
- use std::collections::HashSet;: This line imports the "HashSet" type from the standard library, allowing us to use sets in our code.
- fn is_subset(set1: &HashSet<i32>, set2: &HashSet<i32>) -> bool { ... }: This line defines a function named is_subset that takes two sets (HashSet<i32>) as input references and returns a boolean value indicating whether the first set is a subset of the second set.
- The "is_subset()" function iterates over each element in the first set ('set1') and checks if it is present in the second set ('set2'). If any element of 'set1' is not found in 'set2', the function returns 'false'. Otherwise, it returns 'true' after checking all elements.
- The "main()" function serves as the entry point of the program. It creates two sample sets ('set1' and 'set2') and calls the "is_subset()" function to check if 'set1' is a subset of 'set2'. Finally, it prints the result.
Rust Code Editor:
Previous: Rust Set Symmetric Difference Function.
Next: Rust Check Superset Function.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics