当前位置:首页 > 初赛 > 正文内容

信息学奥赛知识点(十五)----链表

亿万年的星光1年前 (2024-06-15)初赛1506


4.1 基本概念

1)用来存储数据变量叫做数据域。

2)用来存“直接后继(前趋)元素的地址”的指针叫做指针域。

3)数据域和指针域构成的元素叫做结点。

4”->” 箭头运算是结构体指针访问其指向的成员变量的操作符.

4.2单链表

(1)单链表的定义:

1.  struct Node {

2.   int data;

3.   Node * next;

4.  };

5.  Node * p;



(2)单链表的查找

//(按序号查找)在单链表中查找第i个结点 找到则返回存储位置

1. node *search1(node *l,int i) {

2.   node *p;//新建一个结点指针

3.   int j=0;//建立一个计数器

4.   if(i<=0)return NULL;//判断结点位置的合法性

5.   p=l; //新结点p指向头结点l 从头开始扫描

6.   while(p->next!=NULL&&j<i) {

7.    p=p->next;//指向下一结点

8.    j++;//计数

9.   }

10.  if(i==j) return p;//找到了就返回p指针

11.  else return NULL;

12. }



//(按值查找)在单链表中查找值为e的结点  找到返回结点

1.  node *search2(node *l,int e){

2.   node *p;//新建一个结点指针

3.   p=l->next ;//从第一个结点开始,既头结点后面那个

4.   while(p!=NULL){

5.    if(p->data!=e)p=p->next;//指向下个结点

6.    else break;//找到则退出循环

7.      }

8.   return p;//返回p指针

9.  }



(3)单链表的插入

1.  s->data=e; //将结点sdata设置为e

2.  s->next=p->next; //链表指针的赋值,将p的下一个结点的位置赋值给s的下一个结点

3.  p->next=s; //实现插入,把s接到p的下一个结点上




(4)单链表的删除

    

4.3双链表

(1)双链表的定义

1.  struct Node{

2.   //data表示数据

3.      int data;

4.   //pre node表示前趋   

5.      Node *pre;

6.   //next node表示后继    

7.      Node *next;

8.  }Node,*a;





(2)双链表的插入

1.  Node->next=p->next;

2.  p->next->pre=Node;

3.  Node->pre=p;

4.  p->next=Node;



(3)双链表的删除

1.  Node->pre->next=Node->next;

2.  Node->next->pre=Node->pre;


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

分享给朋友:

相关文章

信息学奥赛知识点(十)----计算机安全知识

计算机安全是中最重要的是存储数据安全,其面临的主要威胁包括:计算机病毒、非法访问、计算机电磁辐射、硬件损坏等。计算机病毒是附在计算机软件中的隐蔽的小程序,它和计算机其他程序一样,但会破坏正常的程序和数...

信息学奥赛知识点(八)----计算机网络

信息学奥赛知识点(八)----计算机网络

一、网络的定义所谓计算机网络,就是利用通信线路和设备,把分布在不同地理位置上的多台计算机连接起来。计算机网络是现代通信技术与计算机技术相结合的产物。网络中的计算机与计算机之间的通信依靠协议进行。协议是...

信息学奥赛知识点(四)----计算机语言

信息学奥赛知识点(四)----计算机语言

程序是一系列的操作步骤,计算机程序就是由人事先规定的计算机完成某项工作的操作步骤,每一个步骤具体内容由计算机能够理解的指令来描述,这些指令告诉计算机“做什么”和“怎么做”  &nb...

信息学奥赛知识点(六)----信息编码

信息学奥赛知识点(六)----信息编码

一、基本概念1.编码计算机要处理的数据除了数值数据以外,还有各类符号、图形、图像和声音等非数值数据。而计算机只能识别两个数字。要使计算机能处理这些信息,首先必须将各类信息转换成0和1表示的代码,这一过...

信息学奥赛知识点(十三)----树和二叉树(下)

信息学奥赛知识点(十三)----树和二叉树(下)

一、表达式的求法考试中有经常出现类似于“中缀表达式转后缀”,“前缀表达式转后缀”等。如果能画出唯一的二叉树那么便根据二叉树的结构之间求解即可,有些情况很难直接画出二叉树。还有通过加括号的方式进行求解,...