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

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

亿万年的星光7个月前 (06-15)初赛725


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;


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

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

分享给朋友:

相关文章

2020年CSP-J 初赛题目及答案解析

2020年CSP-J 初赛题目及答案解析

扫码关注下面微信公共号,发送“CSPJ2020”获取文章答案查看详细解题过程:题目及答案下载链接(PDF):https://box356.lanzoub.com/iUllf27ae9gj2020年普及...

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

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

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

NOIP2010年普及组初赛题目及答案解析

NOIP2010年普及组初赛题目及答案解析

单项选择题 (共20题,每题1.5分,共计30分。每题有且仅有一个正确答案。)1.  2E+03 表示(D )A. 2.03      &n...

信息学奥赛知识点(五)----进制转换

信息学奥赛知识点(五)----进制转换

一、进位计数制的基本概念将数字符号按排列成数位,并遵照某种由低到高的进位方式计数表述数值的方法,称为计数制。1.十进制十进制计数由0,1,2,3,4,5,6,7,8,9共10个数字符号组成。相同数字符...

NOIP2012年普及组初赛题目及答案分析

NOIP2012年普及组初赛题目及答案分析

一、单项选择题(共20题,每题1.5分,共计30分;每题且仅有一个正确选项)1.计算机如果缺少(A ),将无法正常启动。A.内存       ...