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

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

亿万年的星光2年前 (2024-06-15)初赛1785


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;


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

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

分享给朋友:

相关文章

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

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

 2021年普及组一、单项选择题1.以下不属于面向对象程序设计语言的是(  )。A.C++        B....

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

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

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

信息学奥赛知识点(一)----计算机基础知识

信息学奥赛知识点(一)----计算机基础知识

1.计算机发展史年代代表原件第一代1946-1958电子管第二代1959-1964晶体管第三代1965-1970集成电路第四代1971—~大规模集成电路2.世界上第一台电子计算机时间:1946年2月地...

信息学奥赛知识点(九)----因特网概述

英特网(Internet),它所采用的网络协议是TCP/IP协议。它是因特网的核心技术。TCP/IP协议,具体地说就是传输控制协议和网际协议。其中,TCP协议用于负责网上信息的正确传输,而IP协议则是...

信息学奥赛知识点(三)----计算机软件系统

信息学奥赛知识点(三)----计算机软件系统

软件是计算机的灵魂,硬件为软件提供了运行平台,软件和硬件相互关联,两者之间相互转换,相互补充。计算机的软件系统分成系统软件和应用软件两大类。一、系统软件常见的操作系统:分为桌面操作系统、服务器操作系统...

2019年CSP-S初赛题目及答案解析

2019年CSP-S初赛题目及答案解析

一、单项选择题1.若定义int a=7; float x=2.5,y=4.7;则表达式x+a%3*int(x+y)%2的值是:()A.0.000000      &nbs...