Rust数据结构和算法系列[4]-链式哈希表

本文深入探讨Rust编程中链式哈希表的实现原理与应用,涵盖数据结构、插入与查找算法,并展示实际运行效果。

 

//链式哈希表,将数据存在桶中
struct chtbale{
    buckets : i32, //桶的个数
    size : i32, //数据数量
    table : Vec<Option<Vec<i32>>>, //哈希表
}
impl chtbale{
    fn hashfunc(&self,data:i32) -> i32{ //哈希函数
        return data  % self.buckets;
    }
    fn lookup(&self,data:i32) -> bool{
        let bucket :i32 = self.hashfunc(data);
        let optionlst  = self.table[bucket as usize].as_ref();
        if let Some(lists) = optionlst{
            if lists.contains(&data){
                return true;
            }
        }
        return false;
    }
    pub fn new(buckets:i32) -> Self{ //初始化桶的数量
        let mut tt :Vec<Option<Vec<i32>>> = Vec::new();
        for _ in 0..buckets{ 
            tt.push(Some(Vec::new()));
        }
        Self{
            buckets:buckets,
            size : 0,
            table : tt,
        }
    }
    pub fn insert(&mut self,data:i32){
        if self.lookup(data) == true{
            return; 
        }
        let bucket :i32 = self.hashfunc(data);
        
        self.table[bucket as usize].as_mut().unwrap().push(data);
        self.size += 1;
    }
    pub fn remove(&mut self,data:i32){
        if self.lookup(data) == false{
            return; 
        }
        let bucket :i32 = self.hashfunc(data);
        let optionlst = self.table[bucket as usize].as_mut();
        if let Some(lists) = optionlst{
            for i in 0..lists.len(){
                if lists[i] == data{
                    lists.remove(i);
                    self.size -= 1;
                }
            }
        }
    }
}
pub fn run(){
    let mut myhash = chtbale::new(10);
    for i in 0..255{
        myhash.insert(i);
    }
    myhash.remove(250);
    for i in 0..10{
        println!("{:?}",myhash.table[i]);
    }
    
}

运行结果如下

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值