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

具体代码如下图:

具体编译结果如下图:

相关推荐
爱吃烤鸡翅的酸菜鱼16 小时前
【Redis】常用数据结构之Hash篇:从常用命令到使用场景详解
数据结构·数据库·redis·后端·缓存·哈希算法
Pretend° Ω16 小时前
LRU缓存详解:用C语言实现高效数据管理
运维·c语言·spring·缓存·lru·双向链表
大千AI助手16 小时前
粒子群优化(PSO)算法详解:从鸟群行为到强大优化工具
人工智能·算法·优化算法·pso·粒子群优化
二进制person17 小时前
数据结构--Map和Set
数据结构
我叫汪枫17 小时前
C语言深度入门系列:第十一篇 - 动态内存管理与数据结构:程序世界的高效算法大师
c语言·数据结构·算法
Li_76953217 小时前
优选算法100 题 ——1 双指针
算法
77qqqiqi17 小时前
算法——数学基础
算法
啊?啊?17 小时前
7 排序算法通关指南:从 O (n²)(选择 / 冒泡)到 O (nlogn)(快排 / 归并)+ 计数排序
数据结构·算法·排序算法
张较瘦_17 小时前
[论文阅读] 算法 | 抗量子+紧凑!SM3-OTS:基于国产哈希算法的一次签名新方案
论文阅读·算法·哈希算法
芒克芒克17 小时前
LeetCode 面试经典 150 题:多数元素(摩尔投票法详解 + 多解法对比)
算法·leetcode·面试