博客
关于我
数据结构之单链表的查找(带头节点)
阅读量:104 次
发布时间:2019-02-26

本文共 950 字,大约阅读时间需要 3 分钟。

按位查找(平均时间复杂度为O(n))

按位查找是一种常见的链表操作方法,用于根据元素的位置索引快速获取特定节点。该操作的平均时间复杂度为O(n),这意味着在最坏情况下需要遍历整个链表才能找到目标节点。

以下是实现按位查找的函数示例:

LNode * GetElem(LinkList L, int i) {    if (i < 0) {        return NULL;    }    LNode *p = L;    int j = 0;    while (p != NULL && j < i) {        p = p->next;        j++;    }    return p;}

这个函数接受链表头节点和目标节点的索引位置i作为输入。通过逐个遍历链表,直到找到目标节点或遍历完链表,函数返回目标节点或NULL(表示索引超出链表长度)。

按值查找(平均时间复杂度为O(n))

按值查找是根据节点的数据值来查找特定节点的操作。这种方法适用于链表中存在多个相同值节点的情况,返回第一个匹配的节点。

以下是实现按值查找的函数示例:

LNode * LocateElem(LinkList L, int e) {    LNode *p = L->next;    while (p != NULL && p->data != e) {        p = p->next;    }    return p;}

该函数接受链表头节点和要查找的数据值e作为输入,返回第一个匹配数据值的节点。如果链表中无匹配节点,则返回NULL。

求表的长度

为了获取链表的长度,可以通过遍历链表并统计节点数来实现。以下是实现求表长度的函数示例:

int length(LinkList L) {    int len = 0;    LNode *p = L;    while (p != NULL && p->next != NULL) {        p = p->next;        len++;    }    return len;}

这个函数遍历链表,直到遇到最后一个节点(即最后一个节点的next属性为NULL)为止。返回遍历过程中统计的节点总数,即链表的长度。

转载地址:http://izyk.baihongyu.com/

你可能感兴趣的文章
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>
NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
查看>>
NLP:使用 SciKit Learn 的文本矢量化方法
查看>>
Nmap扫描教程之Nmap基础知识
查看>>
Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
查看>>
NMAP网络扫描工具的安装与使用
查看>>
NMF(非负矩阵分解)
查看>>
NN&DL4.1 Deep L-layer neural network简介
查看>>
NN&DL4.3 Getting your matrix dimensions right
查看>>
NN&DL4.8 What does this have to do with the brain?
查看>>
No 'Access-Control-Allow-Origin' header is present on the requested resource.
查看>>
NO 157 去掉禅道访问地址中的zentao
查看>>
No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
查看>>
No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
查看>>
No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
查看>>