数据结构和算法-哈希表(散列)3|学习笔记

简介: 快速学习数据结构和算法-哈希表(散列)3

开发者学堂课程【Go 语言核心编程 - 数据结构和算法: 数据结构和算法-哈希表(散列)3】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/627/detail/9867


数据结构和算法-哈希表(散列)3


 基于 hashtable 的雇员关系系统的思路分析

1. 优化代码

package main

Import (

fmt

)

//定义 emp

type Emp struct {

Id int

Name string

Next * Emp

}

//方法待定..

//定义 EmpLink

//我们这里的 EmpLink 不带表头,即第一个节点就存放雇员

type EmpLink struct {

Head * Emp

}

//方法待定.

//1.添加员工的方法,保证添加时,编号从小到大

func (this *EmpLink) Insert(emp *Emp) {

cur := thie.Head // 这是辅助指针

var pre *Emp = nil   //这是一个辅助指针 pre 在 cur 前面

// 如果当前的 EmpLink 就是一个空链表

If cur == nil {

this.Head = emp//完成

return

}

// 如果不是一个空链表,给 emp 找到对应的位置并插入

//思路是让 cur 和 emp 比较,然后让 pre 保持在 cur 前面

for {

If cur !=nil {

//比较

if cur.Id > emp.Id {

//找到位置

break

}

Pre = cur //保证同步

cur = cur.Next

}else {

Break

}

}

//退出时,我们看下是否将 emp 添加到链表最后

pre.Next = emp

emp.Next = cur

}

//显示链表信息

func (this *EmpLink) ShowLink(no int) {

if this. Head == nil {

fmt.Printf(链表%d 为空\n,no)

return

}

//变量当前的链表,并显示数据

cur := this.Head // 辅助的指针

for {

If cur != nil {

fmt.Printf(链表%d 雇员id=%d 名字=%s

->,no,cur.Id,cur.Name)

cur =cur.Next

} else {

Break

}

Fmt.PrintIn()    //换行处理

}

//根据 id 查找对应的雇员,如果没有就返回 nil

Func (this * EmpLink) FindById(id int) *Emp {

Cur := this *Head

For {

If cur != nil && cur.Id == id {

Return cur

}else if cur == nil {

Break

}

cur =cur.Next

}

Return nil

}

//给 HashTable 编写 Insert 雇员的方法.

 func (this *HashTable) Insert (emp *Emp) {

//使用散列函数,确定将该雇员添加到哪个链表

linkNo := this.HashFun(emp.Id)

//使用对应的链表添加

this.LinkArr[linkNo].Insert(emp) //

}

//编写方法,显示 hashtable 的所有雇员

func (this *HashTable) ShowALL() {

for

//编写一个散列方法

func (this *HashTable) HashFun(id int) int {

Return id % 7//得到一个值,就是对于的链表的下标

}

func main() {

for {

fmt.PrintIn(===============雇员系统菜单===============”)

fmt.PrintIn(“input 表示添加雇员”)

Fmt.PrintIn(“show 表示显示雇员”)

fmt.PrintIn(“find 表示查找雇员”)

fmt.PrintIn(“exit 表示退出系统”)

fmt.PrintIn(“请输入你的选择”)

fmt.ScanIn(&key)

switch key {

case input:

fmt.PrintIn(输入雇员id)

fmt.ScanIn(&id)

Fmt.PrintIn(输入雇员name)

Fmt.ScanIn(&name)

emp := &Emp{

Id : id,

Name : name,

}

Hashtable.Insert(emp)

Case show:

Hashtable.ShowAll()

Case exit:

Default:

Fmt.PrintIn(输入错误”)

}

}

}

相关文章
|
1天前
|
数据采集 人工智能 安全
|
11天前
|
云安全 监控 安全
|
2天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
951 151
|
2天前
|
编解码 人工智能 机器人
通义万相2.6,模型使用指南
智能分镜 | 多镜头叙事 | 支持15秒视频生成 | 高品质声音生成 | 多人稳定对话
|
16天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1665 8
|
7天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
619 152
|
9天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
593 16
|
9天前
|
人工智能 自然语言处理 API
Next AI Draw.io:当AI遇见Draw.io图表绘制
Next AI Draw.io 是一款融合AI与图表绘制的开源工具,基于Next.js实现,支持自然语言生成架构图、流程图等专业图表。集成多款主流大模型,提供智能绘图、图像识别优化、版本管理等功能,部署简单,安全可控,助力技术文档与系统设计高效创作。
673 151