c语言-指针(数组)练习2

题目:将数组中n个元素按逆序存放并打印出来,使用函数封装与指针

思路:

1.定义一个数组arr[5]和用于存放数组大小(数组大小通过sizeof关键字来进行计算)的变量len;

2.创建三个函数initArr、printArr、revangeArr,它们的形参都需要接收数组的首地址和大小,因此都需要定义两个形参(*pArr、len)。

2.1 initArr的作用是获取键盘输入的值并通过循环遍历进数组

2.2 printArr的作用是将数组中的元素遍历并打印出来;

3.3 revangeArr的作用是将数组中的元素进行逆序存放。

3.3.1 逆序存放的思路:

首先我们要考虑到数组中元素是奇数个还是偶数个,是否这两种情况的算法都不同。

奇数:奇数个元素的话我们就需要定到中间那个元素,且这个元素不需要交换。举个例

arr[5]={11,22,33,44,55},这个数组中间那个元素是33,对应下标是2,因此只需要 定义一个 i < len/2,j=len-1-i。如下图:

偶数:偶数的元素思路与奇数一样,同样是定位到中间,如下图:

因此,不管奇数还是偶数个元素的数组,利用循环时需要的条件都一致。有了这个思路,那么就只需要再定义一个变量用于值交换时的媒介即可

3.由于都是对数组地址进行操作,因此函数不需要返回值,函数类型就可以是空类型void。

4.在main函数中调用这三个函数就能得到对应的结果

具体代码如下图:

具体编译结果如下图:

相关推荐
SHtop1117 分钟前
排序算法(golang实现)
算法·golang·排序算法
Rain_is_bad41 分钟前
初识c语言————数学库函数
c语言·开发语言·算法
磨十三1 小时前
C++ 类型转换全面解析:从 C 风格到 C++ 风格
java·c语言·c++
Zzzzmo_2 小时前
Java数据结构:ArrayList与顺序表2
java·数据结构
艾醒2 小时前
大模型面试题剖析:模型微调中冷启动与热启动的概念、阶段与实例解析
深度学习·算法
新学笺3 小时前
数据结构与算法 —— 从基础到进阶:带哨兵的单向链表,彻底解决边界处理痛点
算法
智者知已应修善业3 小时前
【51单片机计时器1中断的60秒数码管倒计时】2023-1-23
c语言·经验分享·笔记·嵌入式硬件·算法·51单片机
Jiezcode3 小时前
LeetCode 148.排序链表
数据结构·c++·算法·leetcode·链表
Asmalin3 小时前
【代码随想录day 29】 力扣 406.根据身高重建队列
算法·leetcode·职场和发展
Asmalin3 小时前
【代码随想录day 32】 力扣 70.爬楼梯
算法·leetcode·职场和发展