当前位置: 首页 > news >正文

唐山网站建设哪家专业西安最有名的策划公司

唐山网站建设哪家专业,西安最有名的策划公司,一起做网店潮汕站,网站建设柚子网络科技怎么样注&#xff1a;本文只探讨"带头结点"的情况(查找思路类似循环找到第i-1 个结点的代码) 一.按位查找&#xff1a; 1.代码演示&#xff1a; 版本一&#xff1a; #include<stdio.h> #include<stdlib.h> ​ ​ //定义单链表结点类型 typedef struct LNo…


注:本文只探讨"带头结点"的情况(查找思路类似循环找到第i-1 个结点的代码)

一.按位查找:

1.代码演示:

版本一:
#include<stdio.h>
#include<stdlib.h> 
​
​
//定义单链表结点类型
typedef struct LNode  
{int data; //每个结点存放一个数据元素struct LNode *next; //指针指向下一个结点      
}LNode,*LinkList;
​
​
//初始化一个单链表(带头结点)
bool InitList(LinkList &L)
{L = (LNode *)malloc( sizeof(LNode) ); //分配一个头结点if(L==NULL) //代表内存不足,分配失败-->意味着带头结点的单链表无法创建 {return false;}else{L -> next = NULL; //头结点之后暂时还没有节点,所以指向NULLreturn true; } 
} 
​
​
//判断单链表是否为空(带头结点)
bool Empty(LinkList L)
{if(L->next==NULL) //头结点之后如果指向NULL,代表没有数据 {return true;}else{return false;}
} 
​
​
//按位查找,返回第i个元素(带头结点即第0个结点)
LNode * GetElem(LinkList L,int i)
{if(i<0){return NULL;}LNode *p; //指针p指向当前扫描到的结点 int j=0; //当前p指向的是第几个结点:j为0代表头结点 p=L; //L指向头结点,头结点是第0个结点(不存数据)while(p!=NULL && j<i) //循环找到第i个结点 {p = p->next;j++;}  return p; 
} ​
int main()
{//声明一个指向单链表的指针LinkList L;//初始化一个空表InitList(L); return 0;
} 
版本二:王道书版本
#include<stdio.h>
#include<stdlib.h> 
​
​
//定义单链表结点类型
typedef struct LNode  
{int data; //每个结点存放一个数据元素struct LNode *next; //指针指向下一个结点      
}LNode,*LinkList;
​
​
//初始化一个单链表(带头结点)
bool InitList(LinkList &L)
{L = (LNode *)malloc( sizeof(LNode) ); //分配一个头结点if(L==NULL) //代表内存不足,分配失败-->意味着带头结点的单链表无法创建 {return false;}else{L -> next = NULL; //头结点之后暂时还没有节点,所以指向NULLreturn true; } 
} 
​
​
//判断单链表是否为空(带头结点)
bool Empty(LinkList L)
{if(L->next==NULL) //头结点之后如果指向NULL,代表没有数据 {return true;}else{return false;}
} 
​
​
//按位查找,返回第i个元素(带头结点即第0个结点)
LNode * GetElem(LinkList L,int i)
{int j=1; //代表p结点刚开始指向第一个结点(不是头结点) LNode *p=L->next;if(i==0){return L; //返回头结点 }if(i<1){return NULL;}while(p!=NULL && j<i) //循环找到第i个结点 {p = p->next;j++;}  return p; 
} ​
int main()
{//声明一个指向单链表的指针LinkList L;//初始化一个空表InitList(L); return 0;
} 

2.返回第0个元素即头结点:

3.返回的结点大于链表的长度:

while循环进行到第5次时p指向NULL,不满足下一次循环条件,跳出while循环,此时返回的p为NULL:代表查找失败

最终可知当i值不合法时即i为负数或者i值大于链表长度时最终都返回NULL,因此只需要判断返回结果是否为NULL即可

得知是否查找成功。

4.返回的结点在链表内:

a.计算时间复杂度需要要查找的元素在合法范围内。

b.平均时间复杂度是指此次输入的i值它取的合法范围内的任何一个数字的概率都等可能的情况,

具体的算法和顺序表的按位查找的分析方法一样。

5.封装:

案例一:GetElem用来获取第i个结点,传入参数i-1即可找到第i-1个结点

案例二:后插操作的加入

右下角的InsertNextNode函数中需要一个if(p==NULL)进行是否为空指针的判断,因为如果传入GetElem函数的i值不合法即i-1也不合法,会导致p为NULL即空指针:


二.按值查找:

1.代码演示:

按值查找操作只能从第一个结点开始循环依次向后查找:

#include<stdio.h>
#include<stdlib.h> 
​
​
//定义单链表结点类型
typedef struct LNode  
{int data; //每个结点存放一个数据元素struct LNode *next; //指针指向下一个结点      
}LNode,*LinkList;
​
​
//初始化一个单链表(带头结点)
bool InitList(LinkList &L)
{L = (LNode *)malloc( sizeof(LNode) ); //分配一个头结点if(L==NULL) //代表内存不足,分配失败-->意味着带头结点的单链表无法创建 {return false;}else{L -> next = NULL; //头结点之后暂时还没有节点,所以指向NULLreturn true; } 
} 
​
​
//判断单链表是否为空(带头结点)
bool Empty(LinkList L)
{if(L->next==NULL) //头结点之后如果指向NULL,代表没有数据 {return true;}else{return false;}
} 
​
​
//按值查找,找到数据域等于e的结点
LNode * LocateElem(LinkList L,int e)
{LNode *p= L->next; //L代表头结点,L->next就是第一个节点,此时p就是第一个结点 //从第一个结点开始查找数据域为e的结点(头结点不存数据,所以不从头结点开始)while(p != NULL && p->data != e){p = p->next;}//找到后返回该节点指针,否则返回NULLreturn p; 
} ​
int main()
{//声明一个指向单链表的指针LinkList L;//初始化一个空表InitList(L); return 0;
} 

平均时间复杂度为O(n)。

2.图解:

例一:

p为第一个节点,第一次循环时p不为NULL且p内部的值不为8,符合循环条件,指向p = p->next即向后指一个元素:

第二次循环时p内部的值为8,不符合循环条件,跳出while循环:

例二:

最终返回NULL,代表不存在数据域为6的结点。

3.如果要找的数据域元素不是基本数据类型如结构体类型,就需要复杂的判断:

如结构体(struct)类型要用到运算符"."访问每一个成员变量来比较。


三.求单链表的长度:


四.总结:


http://www.yayakq.cn/news/648832/

相关文章:

  • 建设文明网站包括哪些内容美篇app制作教程
  • 齐齐哈尔做网站的公司营销型网站建设托管
  • 元器件采购最好的网站jsp 网站建设
  • 网络叶子 网站推广北京高端网站建设优势
  • 网站图片多大合适深圳网站建设的
  • php网站开发工程师岗位职责干事儿网网站开发
  • 网站分类有哪几类新闻热点事件2022(最新)最近
  • 海外版tiktok官网入口谷歌seo运营
  • 做薆视频网站网站建设中如何使用字体
  • 网站关键词排名查询平台网站建设教程视频
  • 沂源网站建设wordpress怎样实现前台编辑器
  • 怎么自己创建网站免费做网站的公司倒闭
  • 网站公司怎么做推广方案网站注册域名位置
  • 西安城乡住房建设厅网站首页广元网页制作公司
  • 长春制作公司网站网站分享平台
  • 哪家做网站的公司网站建设杭州
  • 一个月做网站wordpress菜单链接地址
  • 网站建设行业税率有人做网赌网站吗
  • 郑田生网站建设及维护登封哪里有做网站的
  • 公司网站建设华为如何攻击php网站
  • 厦门网站建设哪家厦门建设银行网站建设到底怎么回事
  • 苏州外贸网站制作星凯网站建设
  • 深圳宝安区网站建设公司易班网站建设的意义
  • 住房和城乡建设部网站办事大厅里边有心学做网站
  • 大米网站模板ftp工具下载网站源码教程
  • 北京优化网站免费企业查询软件
  • 免费做简历网站有哪些网页美工怎么做
  • 郑州做网站擎天广告公司网站官网
  • 徐州网站开发设计平台公司名称起名大全
  • 做网站的广告词国外的设计网站app吗