C语言:使用指针打印数组内容-2

简介: 思路三:自定义函数用 while循环 进行循环打印总体思路:(一).自定义函数print: 函数参数:float* p -- 数组首元素地址int sz -- 数组元素个数 使用指针变量表示元素个数:float* q = p + sz;

思路三:自定义函数用 while循环 进行循环打印

总体思路:

(一).

自定义函数print:

函数参数:


float* p -- 数组首元素地址


int sz -- 数组元素个数


           


使用指针变量表示元素个数:


float* q = p + sz;


       


使用 while循环 和 指针变量 打印数组内容:


使用 解引用符号* 获取 指针内容,


获取一位后就 调整一次指针,把指针移向下一位:


*p++ -- 先执行 *p 获取指针内容,再执行 p++ 调整指针


         


(二).


主函数:


         


定义一维数组arr:


float arr[] = { 3.14f, 99.9f, 66.5f, 0.0f };


     


定义指针变量:


float* p = arr; -- 把数组名(数组收元素地址)放进指针变量


         


计算数组元素个数:


int sz = sizeof(arr) / sizeof(arr[0]);  -- 元素个数


       


调用自定义函数:


print(p, sz);

第一步:

自定义函数print:

(1).


函数参数:


float* p -- 数组首元素地址


int sz -- 数组元素个数


           


(2).


使用指针变量表示元素个数:


float* q = p + sz;


       


(3).


使用 while循环 和 指针变量 打印数组内容:


使用 解引用符号* 获取 指针内容,


获取一位后就 调整一次指针,把指针移向下一位:


*p++ -- 先执行 *p 获取指针内容,再执行 p++ 调整指针

实现代码:

#include <stdio.h>
//自定义函数print:
void print(float* p, int sz)
{
  //使用指针变量表示元素个数:
  float* q = p + sz; //此时指针变量在最后一个元素地址
  //使用 while循环 和 指针变量 打印数组内容:
  while (p < q)
    //对比地址大小,只要还小于最后一个元素地址就循环
  {
    printf("%.2f ", *p++);
    //*p++ , 先解引用 ,后再p++
  }
}
int main()
{
  return 0;
}

实现图片:


image.png

第二步:

主函数

(1).


定义一维数组arr:


float arr[] = { 3.14f, 99.9f, 66.5f, 0.0f };


     


(2).


定义指针变量:


float* p = arr; -- 把数组名(数组收元素地址)放进指针变量


         


(3).


计算数组元素个数:


int sz = sizeof(arr) / sizeof(arr[0]);  -- 元素个数


       


(4).


调用自定义函数:


print(p, sz);

实现代码:

#include <stdio.h>
//自定义函数print:
void print(float* p, int sz)
{
  //使用指针变量表示元素个数:
  float* q = p + sz; //此时指针变量在最后一个元素地址
  //使用 while循环 和 指针变量 打印数组内容:
  while (p < q)
    //对比地址大小,只要还小于最后一个元素地址就循环
  {
    printf("%.2f ", *p++);
    //*p++ , 先解引用 ,后再p++
  }
}
int main()
{
  //定义一维数组:
  float arr[] = { 3.14f,99.9f,66.5f,0.0f };
  //定义指针变量:
  float* p = arr; //把数组名(首地址)放进指针中
  //计算数组元素个数:
  int sz = sizeof(arr) / sizeof(arr[0]);//元素个数
  //调用自定义函数进行打印数组元素:
  print(p, sz);
  return 0;
}

实现图片:

image.png

思路三:最终代码和实现效果

最终代码:

#include <stdio.h>
//自定义函数print:
void print(float* p, int sz)
{
  //使用指针变量表示元素个数:
  float* q = p + sz; //此时指针变量在最后一个元素地址
  //使用 while循环 和 指针变量 打印数组内容:
  while (p < q)
    //对比地址大小,只要还小于最后一个元素地址就循环
  {
    printf("%.2f ", *p++);
    //*p++ , 先解引用 ,后再p++
  }
}
int main()
{
  //定义一维数组:
  float arr[] = { 3.14f,99.9f,66.5f,0.0f };
  //定义指针变量:
  float* p = arr; //把数组名(首地址)放进指针中
  //计算数组元素个数:
  int sz = sizeof(arr) / sizeof(arr[0]);//元素个数
  //调用自定义函数进行打印数组元素:
  print(p, sz);
  return 0;
}


实现效果:

f3e8a1397d2e4349b690356ea2837b78.png 

相关文章
|
15天前
使用指针访问数组元素
【10月更文挑战第30天】使用指针访问数组元素。
30 3
|
27天前
|
C语言
【c语言】指针就该这么学(1)
本文详细介绍了C语言中的指针概念及其基本操作。首先通过生活中的例子解释了指针的概念,即内存地址。接着,文章逐步讲解了指针变量的定义、取地址操作符`&`、解引用操作符`*`、指针变量的大小以及不同类型的指针变量的意义。此外,还介绍了`const`修饰符在指针中的应用,指针的运算(包括指针加减整数、指针相减和指针的大小比较),以及野指针的概念和如何规避野指针。最后,通过具体的代码示例帮助读者更好地理解和掌握指针的使用方法。
45 0
|
14天前
使用指针访问数组元素
【10月更文挑战第31天】使用指针访问数组元素。
27 2
|
23天前
|
算法 索引
单链表题+数组题(快慢指针和左右指针)
单链表题+数组题(快慢指针和左右指针)
28 1
|
28天前
|
存储 编译器 C语言
【c语言】数组
本文介绍了数组的基本概念及一维和二维数组的创建、初始化、使用方法及其在内存中的存储形式。一维数组通过下标访问元素,支持初始化和动态输入输出。二维数组则通过行和列的下标访问元素,同样支持初始化和动态输入输出。此外,还简要介绍了C99标准中的变长数组,允许在运行时根据变量创建数组,但不能初始化。
37 6
|
25天前
|
C语言
【c语言】指针就该这么学(3)
本文介绍了C语言中的函数指针、typedef关键字及函数指针数组的概念与应用。首先讲解了函数指针的创建与使用,接着通过typedef简化复杂类型定义,最后探讨了函数指针数组及其在转移表中的应用,通过实例展示了如何利用这些特性实现更简洁高效的代码。
15 2
|
26天前
|
C语言
如何避免 C 语言中的野指针问题?
在C语言中,野指针是指向未知内存地址的指针,可能引发程序崩溃或数据损坏。避免野指针的方法包括:初始化指针为NULL、使用完毕后将指针置为NULL、检查指针是否为空以及合理管理动态分配的内存。
|
26天前
|
C语言
C语言:哪些情况下会出现野指针
C语言中,野指针是指指向未知地址的指针,通常由以下情况产生:1) 指针被声明但未初始化;2) 指针指向的内存已被释放或重新分配;3) 指针指向局部变量,而该变量已超出作用域。使用野指针可能导致程序崩溃或不可预测的行为。
|
1月前
|
存储 C语言
C语言32位或64位平台下指针的大小
在32位平台上,C语言中指针的大小通常为4字节;而在64位平台上,指针的大小通常为8字节。这反映了不同平台对内存地址空间的不同处理方式。
|
1月前
|
存储
如何使用指针数组来实现动态二维数组
指针数组可以用来实现动态二维数组。首先,定义一个指向指针的指针变量,并使用 `malloc` 为它分配内存,然后为每个子数组分配内存。通过这种方式,可以灵活地创建和管理不同大小的二维数组。