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函数中调用这三个函数就能得到对应的结果

具体代码如下图:

具体编译结果如下图:

相关推荐
励志要当大牛的小白菜2 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970442 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵3 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱装代码的小瓶子4 小时前
数据结构之队列(C语言)
c语言·开发语言·数据结构
爱喝矿泉水的猛男5 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao5 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
YouQian7726 小时前
Traffic Lights set的使用
算法
快乐飒男6 小时前
哈希表(c语言)
c语言·哈希算法·散列表
go54631584657 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae7 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法