C语言:指针数组与指针指针的应用解析

需积分: 0 1 下载量 97 浏览量 更新于2024-07-14 收藏 482KB PPT 举报
本文主要探讨了C语言中关于指针数组和指针的指针的使用,特别是如何处理错误的插入位置。在链表操作中,正确地插入新节点至关重要,文章通过示例代码展示了错误检查和节点插入的方法。同时,文章回顾了指针和数组的基础知识,帮助理解指针数组和指针的指针的概念。 首先,让我们回顾一下指针的基本概念。在C语言中,指针是一个变量,它存储的是另一个变量的地址。定义一个指针的语法是`类型标识符*变量名`,例如`int *p`表示`p`是一个指向整型变量的指针。指针可以被赋值为其他变量的地址或者同类型的指针变量。数组则是一组相同类型的数据集合,数组名代表了整个数组的首地址,它是一个常量指针。 数组和指针有着密切关系。数组名可以被视为指向数组第一个元素的指针,因此可以对数组名进行解引用操作,访问数组的第一个元素。例如,对于整型数组`int a[3]`,`a`实际上是一个指向`int`类型的指针,`a+1`则是指向数组第二个元素的指针。此外,`sizeof(a)`返回整个数组的大小,而`sizeof(a+1)`返回一个指针的大小。 指针数组是一种特殊的数组,它的每个元素都是一个指针。例如,`int *a[3]`定义了一个包含三个整型指针的数组。这种类型的数组可以用来存储一系列指针,每个指针可以指向不同的数据。在示例代码中,`int *p[3], *pa, a=12, b=20;`定义了指针数组`p`和指针变量`pa`,并将`pa`和`b`的地址赋值给了数组`p`的元素。 在链表操作中,插入新节点涉及到对指针的修改。在给出的代码段中,错误插入位置的检查是通过`if (pre==NULL || k>i-1)`实现的,确保插入位置有效。然后,通过`p->next = pre->next; pre->next = p;`来正确地插入新节点到链表中。这里的`pre`和`p`分别代表前一个节点和新节点。 接着,文章提供了两个例子来展示指针数组的应用。例14.5展示了如何使用指针数组输出多个字符串,`char*ps[4]={"Unix","Linux","Windows","Dos"}`定义了一个包含四个字符串指针的数组,`for`循环遍历并使用`puts`函数输出每个字符串。 例14.6则展示了如何使用指向指针的指针变量`name`来反向输出一组字符串。`char*name[]`定义了包含五个字符串指针的数组,通过反向遍历数组,`printf`打印出每个字符串,实现了反序输出。 本文深入浅出地介绍了C语言中指针数组和指针的指针的概念,并通过实例展示了它们的实际应用,有助于读者理解这些复杂数据结构的使用方法。