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

具体代码如下图:

具体编译结果如下图:

相关推荐
is081524 分钟前
STM32的 syscalls.c 和 sysmem.c
c语言·stm32·嵌入式硬件
张人玉1 小时前
C# 常量与变量
java·算法·c#
学不动CV了1 小时前
数据结构---链表结构体、指针深入理解(三)
c语言·arm开发·数据结构·stm32·单片机·链表
weixin_446122462 小时前
LinkedList剖析
算法
百年孤独_3 小时前
LeetCode 算法题解:链表与二叉树相关问题 打打卡
算法·leetcode·链表
我爱C编程3 小时前
基于拓扑结构检测的LDPC稀疏校验矩阵高阶环检测算法matlab仿真
算法·matlab·矩阵·ldpc·环检测
算法_小学生3 小时前
LeetCode 75. 颜色分类(荷兰国旗问题)
算法·leetcode·职场和发展
运器1233 小时前
【一起来学AI大模型】算法核心:数组/哈希表/树/排序/动态规划(LeetCode精练)
开发语言·人工智能·python·算法·ai·散列表·ai编程
算法_小学生3 小时前
LeetCode 287. 寻找重复数(不修改数组 + O(1) 空间)
数据结构·算法·leetcode
岁忧3 小时前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表