`

指向结构体变量的指针与链表结构的关系应用

c++ 
阅读更多

指向结构体变量的指针与链表结构的关系应用

1、   一个结构体变量的指针就是该变量所占据的内存段的起始地址。可以设一个指针变量,用来指向一个结构体变量,此时该指针变量的值是结构体变量的其实地址。指针变量也可以用来指向结构体数组的元素。

例如:声明一个结构体Student类型,定义一个Student结构体类型变量stu,声明一个Student指针*p指向stu的地址,我们可以通过stu调用Student结构体类型的成员变量,相应的,因为*p指向stu的内存的起始位置,所以我们可以通过调用*p来调用stu的成员变量,例如:(*p).name,(*p).age来赋值操作等等,注意*p的括号不可省略,因为成员运算符”.”优先级大于”*”。

2、   指向运算符

为了使用方便直观,C++提供了指向结构体变量的运算符->,例如:p->num表示指向p当前指向的结构体变量中的成员num。p->num和(*p).num等价。

总结:如下三种形式等价:

  结构体变量.成员名。如stu.num

  (*p).成员名。如:(*p).num

  p->成员名。如p->num。”->”称为指向运算符。

分析如下几种运算:

 p->n:得到p指向的结构体变量中的成员n的值

p->n++:得到p指向的结构体变量中的成员

n的值,用完该值后使它加1.

++p->n:得到p指向的结构体变量中的成员n的值,并使之加1然后再使用。

3、   用结构体变量和指向结构体变量的指针构成链表

a) 链表是一种常见的重要的数据结构。

b) 链表有一个“头指针“变量,用来存放一个地址。该地址指向一个元素。链表中的每一个元素称为”结点“,每个结点都应包括两个部分:一是用户需要用的实际数据,二是下一个结点的地址。最后一个元素不再指向其他元素,称为”表尾“,它的地址部分放一个”NULL“(空地址),链表到此结束。

c)  链表中各元素在内存中的存储单元可以是不连续的。查找元素可以通过前后链表之间的关系查找,前一个链表的第二个元素的地址是下一个链表的第一个元素。

d) 这种链表的数据结构,必须利用结构体变量和指针才能实现。可以声明一个结构体类型,包含两种成员,一种是用户需要用的实际数据,另一种是用来存放下一个结点地址的指针变量。例如:

struct Student

  { 

int num;

float score;

Student*next;

};

           其中成员num和score是用户需用用到的数据,next是指针类型的成员,指向Student类型数据,用来存放下一个结点的地址。设计者不必知道各个结点的具体地址,只要保证能将下一个节点的地址放到前一个结点的成员next中即可。

建立并输出一个简单链表:

 /*

 *table.cpp

 *

 * Created on: 2012-4-8

 *     Author: David

 */

 

#define NULL 0

#include<iostream>

 

struct Student

{

  long num;

  float score;

  struct Student *next;

};

 

int main()

{

  Studenta,b,c,*head,*p;

  a.num=31001;a.score=89.5;//对结点anumscore成员赋值

  b.num=31003;b.score=90;//对结点bnumscore成员赋值

  c.num=31007;c.score=85;//对结点cnumscore成员赋值

  head=&a;     //将结点a的起始地址赋给头指针head

  a.next=&b;   //将结点b的起始地址赋给a结点的next成员

  b.next=&c;   //将结点b的起始地址赋给b结点的next成员

  c.next=NULL;//结点的next成员不存放其他结点地址

  p=head;     //p指针指向a结点

 

  do

  {

    cout<<p->num<<""<<p->score<<endl; //输出p指向的结点的数据

    p=p->next;   //使p指向下一个结点

  }

  while(p!=NULL); //输出完c结点后p的值为NULL

  return 0;

}

 

开始时使head指向a结点,a.next指向b结点,b.next指向c结点,这就构成链表关系。第一行用#define命令定义了符号常量NULL代表0,在16行将0地址赋给c.next的作用是使c.next不指向任何有用的存储单元。

4、   静态链表:所有结点(结构体变量)都是在程序中定义的,不是临时开辟的,也不用用完后释放,这种链表称为静态链表。

5、   动态链表:各结点是可以随时插入和删除的,这些结点并没有变量名,只能先找到上一个结点,才能根据它提供的下一结点的地址找到下一个结点。

6、   只提供第一个结点的地址叫做头指针head,只有有了头指针,链表才能访问整个链表。

分享到:
评论

相关推荐

    用C语言结构体类型指针实现数据结构链表操作.pdf

    结构体类型数据的指针指向结构体变量的首地址,通过结构体指针可以操作结构体变量中的成员。结构体指针的引用有三种方式:一是直接通过结构体变量名和成员名来引用;二是通过指针变量和成员名来引用;三是通过指针...

    c语言中的链表-用结构体和指针构造链表

    在C语言中,链表是一种常见的数据结构,它由一系列节点组成,每个节点包含数据部分和指向下一个节点的指针。链表可以动态地增长和缩小,这使得它非常适合处理动态数据集。本文将详细介绍如何使用C语言的结构体和指针...

    结构体数据类型与链表

    链表是一种线性数据结构,它的每个元素(节点)包含数据和指向下一个节点的指针。与数组不同,链表的元素在内存中不是连续存储的。链表的主要优点是插入和删除操作相对快速,因为只需要改变相邻节点的指针。 链表的...

    单向链表(一) 结构体、创建链表、遍历链表

    单向链表是一种基本的数据结构,它在计算机科学和编程中有着广泛的应用。与数组不同,链表中的元素不是在内存中连续存储的,而是通过指针连接起来。本篇文章将深入探讨单向链表的基本概念,包括其结构体定义、如何...

    结构体、指针的应用

    结构体的首地址是指向结构体变量的第一个字节的内存地址。由于计算机通常按字节对齐存储数据,结构体的大小可能不是其成员大小之和。在这个例子中,`Person`结构体的大小取决于`name`数组的大小,加上`age`的4个字节...

    结构体与共用体链表PPT学习教案.pptx

    6. 链表与结构体 结构体是构建链表的基础。链表是一种动态数据结构,每个节点包含数据部分(结构体)和指向下一个节点的指针。通过指针链接,链表可以灵活地插入和删除元素,而不必移动其他元素。例如,可以定义一个...

    结构体与链表 ppt课件

    链表可以是单向链表(每个节点仅有一个指向前一个节点的指针)或双向链表(每个节点有两个指针,分别指向前一个和后一个节点)。 链表的主要操作包括插入节点、删除节点、遍历链表和查找特定节点等。由于链表的动态...

    C++中指向结构体变量的指针

    总结来说,C++ 中的结构体变量指针允许我们高效地处理复杂的数据结构,通过指针可以灵活地访问和操作结构体的各个成员。这种能力对于实现各种算法和数据结构,如链表、树、图等,都具有基础性的作用。理解和熟练掌握...

    结构体数据类型与链表章C语言程序设计教程 PPT学习教案.pptx

    2. **结构体变量的声明与初始化** 定义了结构体类型后,可以声明结构体变量,例如: ```c struct student s1; ``` 初始化结构体变量可以通过花括号{},提供具体的值,如下所示: ```c struct student s1 = {1...

    用C语言中的指针处理数据结构中的链表的方法.pdf

    在C语言中,我们通常会定义一个结构体类型来表示链表节点,然后使用结构体变量和指针变量来创建链表,并对其进行各种操作,如创建节点、链表的遍历、插入、删除等。 总的来说,使用C语言中的指针来处理链表能够有效...

    实验九 结构体数据类型和链表1

    链表是一种线性数据结构,由一系列节点组成,每个节点包含数据和指向下一个节点的指针。与数组不同,链表的元素不需连续存储,这使得插入和删除操作相对更高效,因为不需要移动大量元素。 5. **链表的操作**: 对...

    C语言 实验八 结构体和共用体实验.doc

    同时,掌握指向结构体变量的指针变量的概念和应用,特别是链表的概念和应用。此外,还需要掌握运算符“.”和“-&gt;”的应用,以及共同体的概念和应用。 二、结构体类型的概念和定义方法 在 C 语言中,结构体是一种...

    C语言链表结构体与链表免费版免费下载

    在C语言中,链表是一种重要的数据结构,它是由一系列节点组成,每个节点包含数据以及指向下一个节点的指针。本教程将详细讲解如何利用结构体来实现链表,并提供免费下载资源。以下是对相关知识点的详细说明: 1. **...

    如何学习C语言-结构体与共用体.docx

    指向结构体的指针是指向结构体变量的指针,例如:struct student *p; p = &student1;这里p是指向student1的指针。指向结构体变量的指针使用-&gt;运算符,例如:p-&gt;num = 10; 等价于 student1.num = 10; 链表是指向...

    全国计算机等级考试二级C语言题型总结五之结构体和链表部分.pdf

    - 可以声明结构体变量,如`s1`,也可以声明结构体指针`ps`指向结构体变量。 - 使用点操作符(`.`)和指针箭头操作符(`-&gt;`)访问结构体成员。 - 结构体数组的声明,如`stu[3]`,可以用来存储多个结构体变量。 3....

    C语言结构体与链表.ppt

    链表的每个节点都包含一个指针,指向下一个节点。链表的应用非常广泛,例如构建手机通讯录、管理大量数据等。 程序设计实例 以下是一个简单的手机通讯录程序的设计实例: ```c #include #include struct friend_...

    详解C++中的指针结构体数组以及指向结构体变量的指针

    一个结构体变量中可以存放一组数据(如一个学生的学号、姓名、成绩等数据)。如果有10个学生的数据需要参加运算,显然应该用数组,这就是结构体数组。结构体数组与以前介绍过的数值型数组的不同之处在于:每个数组...

    C 指针与链表

    【指针与链表】是C语言中非常重要的概念,它们是实现复杂数据结构和算法的基础。本实验报告主要探讨了如何使用指针操作链表,以及如何利用指针实现堆栈和队列的基本操作。 首先,理解【指针】的概念至关重要。指针...

    c语言指针和结构体链表详解ppt课件.ppt

    C 语言指针和结构体链表详解 本资源主要讲解了 C 语言中的指针和结构体链表...本资源为读者提供了 C 语言指针和结构体链表的基础知识和应用,涵盖了链表的基本概念、链表的基本操作、链表的实现方法和链表的应用场景。

    c语言13-结构体、联合体、链表(ppt文档).ppt

    链表是一种动态数据结构,其节点在内存中不是连续存储的,每个节点包含数据以及指向下一个节点的指针。链表的常见操作包括遍历、插入和删除节点。双向链表则包含两个指针,分别指向前后相邻的节点,而循环链表则让...

Global site tag (gtag.js) - Google Analytics