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

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

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


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;


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

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

分享给朋友:

相关文章

信息学奥赛知识点(十一)----逻辑运算

一、介绍逻辑运算又称布尔运算。布尔用数学方法研究逻辑问题,成功地建立了逻辑演算。他用等式表示判断,把推理看作等式的变换。这种变换的有效性不依赖人们对符号的解释,只依赖于符号的组合规律 。二、...

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

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

一、单项选择题(共20题,每题1.5分,共计30分。每题有且仅有一个正确答案。)1、 关于图灵机下面的说法哪个是正确的:( D)A.图灵机是世界上最早的电子计算机。B.由于大量使用磁带操作,图灵机运行...

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

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

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

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

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

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

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

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

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

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

扫码关注下面微信公共号,发送“CSPJ2019”获取文章答案查看详细解题过程:原版初赛题目下载链接:CSP-J相关资料 - 青少年编程知识记录 (codecoming.com)答案:解析:2019年普...