C语言练习题-指针-(编写一个函数,接受一个整型数组和数组的长度作为参数,将数组中的元素按逆序存放)

文章目录

  • 前言
  • 题目
    • 题目1
      • 简单的代码框架
    • 题目2
      • 测试用例
    • 题目3
      • 测试用例
  • 参考答案
    • 题目1
      • 答案1
        • 解析
      • 答案2
        • 解析
    • 题目2
      • 答案1
      • 答案2
    • 题目3
      • 答案1
      • 答案2
  • 其他文章

前言

本篇文章的题目为C的基础练习题,指针部分。做这些习题之前,你需要确保已经学习了指针的知识。
本篇文章可以用来在学完指针后加深印象,也可以用于大学课后习题。

题目

题目1

编写一个函数,接受一个整型数组和数组的长度作为参数,将数组中的元素按逆序存放。

输入示例:
{1,2,3,4,5,6}
输出示例:
6 5 4 3 2 1

在这里插入图片描述

简单的代码框架

#include <stdio.h>
void reverseArray(int *arr, int length);
int main(void)
{int arr[] = {1, 2, 3, 4, 5, 6};reverseArray(arr, 6);for (int i = 0; i < 6; i++){printf("%d ", arr[i]);}getchar();getchar();return 0;
}
void reverseArray(int *arr, int length)
{//在此处编写你的答案
}

题目2

编写一个程序,定义一个整型数组,长度为10。从键盘输入10个整数,将它们存储到数组中。
再编写一个函数,接受一个指向数组的指针和数组的长度作为参数,计算数组中所有元素的和,并返回结果。
在主函数中调用该函数,计算并打印数组中所有元素的和。
在这里插入图片描述

测试用例

运行这个程序时,可以输入以下两组测试数据进行验证:

输入:
2 4 6 8 10 12 14 16 18 20
输出:
数组中所有元素的和为:110

输入:
-1 0 1 2 3 4 5 6 7 8
输出:
数组中所有元素的和为:35

题目3

编写一个程序,定义一个整型数组,长度为5。从键盘输入5个整数,将它们存储到数组中。然后编写一个函数,接受一个指向数组的指针和数组的长度作为参数,计算数组中最大值的索引,并返回该索引。最后在主函数中调用该函数,计算并打印数组中最大值的索引。
在这里插入图片描述

测试用例

运行这个程序时,可以输入以下两组测试数据进行验证:

输入:
1 2 3 4 5
输出:
数组中最大值的索引为:4

输入:
-3 0 9 -2 6
输出:
数组中最大值的索引为:2

参考答案

题目1

答案1

void reverseArray(int *arr,int length)
{int i,temp;for(i=0;i<length/2;i++){temp=arr[i];arr[i]=arr[length-i-1];arr[length-i-1]=temp;}
}
解析

使用一个 for 循环来遍历数组的前半部分。循环中,通过一个临时变量 temp 来保存当前元素的值,然后将数组首尾对应的两个元素交换位置。具体来说,将 arr[i] 的值赋给 arr[length-i-1],再将 temp 的值赋给 arr[i],完成两个元素的交换。

循环的终止条件是 i < length/2,这是因为只需要遍历数组的前半部分,后半部分的元素已经在交换过程中完成了逆序排列。

答案2

void reverseArray(int *arr, int length)
{int left = 0;int right = length - 1;while (left < right){// 交换元素int temp = arr[left];arr[left] = arr[right];arr[right] = temp;// 移动指针left++;right--;}
}
解析

与前面的代码不同的是,这里使用了一个 while 循环来达到逆序排列的目的。

在循环的判断条件中,left 表示当前遍历数组元素的左指针,right 表示当前遍历数组元素的右指针。只有当 left 小于 right 时,才需要进行元素交换和指针移动操作。这是因为当 left 和 right 指针相遇时,数组的中心元素已经排列好了。

循环体内部,通过一个临时变量 temp 来保存当前左指针 arr[left] 所指向的元素的值。然后将右指针 arr[right] 所指向的元素的值赋给左指针 arr[left],最后将临时变量 temp 的值赋给右指针 arr[right],完成两个元素的交换。

之后,通过 left++ 和 right-- 分别将左指针和右指针向中间移动一位,进入下一次循环,继续进行元素交换和指针移动操作,直到 left 不再小于 right,循环结束。

这样,整个数组的元素就会被逆序排列。相比于前面的代码,这种方法更加简洁,只需要一个 while 循环就可以完成逆序排列。

题目2

答案1

#include <stdio.h>
#define LEN 10
int arrSum(int arr[],int len);
int main()
{int arr[LEN],sum;for(int i=0;i<10;i++){scanf("%d",&arr[i]);}sum=arrSum(arr,LEN);printf("数组中所有元素的和为:%d\n",sum);getchar();getchar();return 0;
}
int arrSum(int arr[],int len)
{int sum=0;for(int i=0;i<len;i++){sum+=arr[i];}return sum;
}

答案2

#include <stdio.h>// 计算数组中所有元素的和
int sumOfArray(int *arr, int length)
{int sum = 0;for (int i = 0; i < length; i++){sum += *(arr + i);}return sum;
}int main()
{int arr[10];for (int i = 0; i < 10; i++){scanf("%d", &arr[i]);}int sum = sumOfArray(arr, 10);printf("数组中所有元素的和为:%d\n", sum);getchar();getchar();return 0;
}

题目3

答案1

#include <stdio.h>
# define LEN 5
int maxIndex(int arr[],int len);
int main()
{int arr[LEN];for(int i=0;i<LEN;i++){scanf("%d",&arr[i]);}int index=maxIndex(arr,LEN);printf("数组中最大值的索引为:%d\n",index);getchar();getchar();return 0;
}
int maxIndex(int arr[],int len)
{int index=0;for (int i = 1; i < len; i++){if(arr[i]>arr[index])index=i;}return index;    
}

答案2

#include <stdio.h>int findMaxIndex(int *arr, int length)
{int maxIndex = 0;for (int i = 1; i < length; i++){if (*(arr + i) > *(arr + maxIndex)){maxIndex = i;}}return maxIndex;
}int main()
{int arr[5];for (int i = 0; i < 5; i++){scanf("%d", &arr[i]);}int maxIndex = findMaxIndex(arr, 5);printf("数组中最大值的索引为:%d\n", maxIndex);getchar();getchar();return 0;
}

其他文章

添加链接描述C#练习题-构造函数
C语言编写图形界面

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/139089.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MAYA教程之建模基础命令介绍

基础命令 视图相关操作 旋转视图 : ALT 鼠标左键平移视图 : ALT 鼠标中键缩放视图 : 滚动鼠标滚轮 或者 ALT 鼠标右键切换视图 : 空格键回到模型 : F 视图状态 选择状态 : Q移动状态 : W旋转状态 : E缩放状态 : R 视图显示 正常显示 : 1正常圆滑同时显示 : 2圆滑显示 …

说明书SMW200A信号发生器

罗德与施瓦茨SMW200A信号发生器 满足您的所有要求 频率范围介于 100 kHz 至 3 GHz、6 GHz、12.75 GHz、20 GHz、31.8 GHz 或 40 GHz 可选的附加射频路径&#xff08; 100 kHz 至 3 GHz、6 GHz、12.75 GHz 或 20 GHz&#xff09; 通用配置&#xff1a; 从单通道矢量信号发生器到…

填充颜色游戏

无语死了这题。 题目描述 小明最近迷上下面一款游戏。游戏开始时&#xff0c; 系统将随机生成一个 N N 的 正方形棋盘&#xff0c; 棋盘的每个格子都由六种颜色中的一种绘制。在每个步骤中&#xff0c; 玩家选择一种颜色&#xff0c; 并将与左上角连接的所有网格更改为该特…

ITextRenderer将PDF转换为HTML详细教程

引入依赖 <dependency><groupId>org.xhtmlrenderer</groupId><artifactId>flying-saucer-pdf-itext5</artifactId><version>9.1.18</version></dependency> 问题一&#xff1a;输出中文字体 下载字体simsun.ttc 下载链接&am…

24届好未来数开笔试

目录 选择、多选SQL题目描述输入 目标解答解析 题目分享 选择、多选 Java, int x 1, float y 2, x/y 0.5 2. Hive 的数据结构 基本数据类型 复合数据类型 text 不是 Hive 内外表 建表时如果不显示声明表的类型为 外表 Kafka 通过&#xff08;&#xff09;避免任务重复执行…

《开箱元宇宙》:《福布斯》如何通过 Web3 改进讲故事的方式

你们是否想知道 The Sandbox 如何融入世界上最具标志性的品牌和名人的战略&#xff1f;在本期《开箱元宇宙》系列中&#xff0c;我们与《福布斯》一起探讨了他们为何决定在 The Sandbox 中尝试 Web3&#xff0c;以及他们如何改变讲故事的方式&#xff0c;以便在一次体验中吸引超…

[SQL | MyBatis] MyBatis 简介

目录 一、MyBatis 简介 1、MyBatis 简介 2、工作流程 二、入门案例 1、准备工作 2、示例 三、Mapper 代理开发 1、问题简介 2、工作流程 3、注意事项 4、测试 四、核心配置文件 mybatis-config.xml 1、environment 2、typeAilases 五、基于 xml 的查询操作 1、…

AR智能眼镜主板设计方案_AR眼镜PCB板设计

AR智能眼镜是一种采用先进技术的创新产品&#xff0c;具备强大的功能和性能。它采用了MTK8788八核 12nm低功耗硬件平台&#xff0c;搭载IMG GE830063OMhz或以上的GPU&#xff0c;并运行Android 11.0或以上的操作系统。该眼镜支持光波导1080P显示和LVDS接口自由曲面显示&#xf…

CSS详细解析二

05-显示模式 显示模式&#xff1a;标签&#xff08;元素&#xff09;的显示方式。 作用&#xff1a;布局网页的时候&#xff0c;根据标签的显示模式选择合适的标签摆放内容。 块级元素 特点&#xff1a; 独占一行 宽度默认是父级的100% 添加宽高属性生效 行内元素 特…

基于Springboot实现在线答疑平台系统项目【项目源码+论文说明】计算机毕业设计

基于Springboot实现在线答疑平台系统演示 摘要 社会的发展和科学技术的进步&#xff0c;互联网技术越来越受欢迎。网络计算机的生活方式逐渐受到广大师生的喜爱&#xff0c;也逐渐进入了每个学生的使用。互联网具有便利性&#xff0c;速度快&#xff0c;效率高&#xff0c;成本…

Messari发布Moonbeam简报,每日交易量稳步增长,首次公布利润数据

区块链数据公司Messari首次发布Moonbeam项目分析简报&#xff0c;从项目市值、链上数据表现、质押以及Moonbeam的技术优势XCM使用量等角度全面分析。这个再熊市初期上线的项目一直在默默开发&#xff0c;并在跨链互操作领域拥有了相当的实操成绩。我们翻译了Messari简报中的部分…

Element-UI 日期选择器--禁用未来日期

在做项目的时候经常会遇到一些报表需要填写日期&#xff0c;一般是填写当日及当日以前&#xff0c;这时候我们的日期选择器就需要进行一些限制&#xff0c;比如&#xff1a; 这样之后&#xff0c;就不会误填写到明天啦&#xff0c;下面让我们看一下代码实现 html页面代码 这里…