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

news2025/3/15 18:59:35

文章目录

  • 前言
  • 题目
    • 题目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.coloradmin.cn/o/1103649.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

session 反序列化

原理详解 ctfshow 新手杯 剪刀石头布 这里我们可以发现服务器使用的处理器为php_serialize&#xff0c;与当前页面处理器不同&#xff0c;在反序列化的时候会造成一些问题。同时cleanup配置没开&#xff0c;关闭了session自动清理&#xff0c;所以我们不需要进行条件竞争。并…

pointnet和pointnet++点云分割和分类

目录 1. pointnet 1.1 点云数据的特点 1.2 模型功能 1.3 网络结构 1.3.1 分类网络 1.3.2 分割网络 2. pointnet 2.1 模型 2.2 sampling layer组件 2.3 grouping layer 2.4 pointnet 1. pointnet 1.1 点云数据的特点 &#xff08;1&#xff09;无序性&#xff1a…

深度学习——批量规范化(Batch Normalization)

深度学习——批量规范化&#xff08;Batch Normalization&#xff09; 文章目录 前言一、训练深层网络二、批量规范化层2.1. 全连接层2.2. 卷积层2.3. 预测过程中的批量规范化 三、从零实现四、使用批量规范化层的LeNet五、简洁实现六、小结总结 前言 训练深层神经网络是十分困…

三极管从入门到精通

文章目录 摘要1 基础1.1 PN结1.2 三极管 2 三极管模拟电路知识2.1 I-V特性曲线2.2 极限参数解释2.3 基本共射极放大电路2.4 小信号模型2.5 用小信号模型分析基本共射极放大电路 3 三极管实际模拟电路应用图3.1 共射极放大电路3.1.1 基本共射极放大电路3.1.2 基极分压式射极偏置…

深度学习——使用kaggle中的GPU资源

文章目录 前言一、使用流程二、数据集加载总结 前言 之前都是使用CPU来进行模型训练&#xff0c;对于一些小模型还好&#xff0c;等神经网络越来越深&#xff0c;所需计算资源也越来越大&#xff0c;时间耗费也越来越多&#xff0c;这时我们需要使用GPU来进行加速。本章将介绍…

电源模块测试用例科普:如何调整电压调整率?ATECLOUD-POWER测试系统能否测试?

电压调整率可以控制电压水平&#xff0c;确保设备正常工作&#xff0c;并且可以减少电能浪费&#xff0c;是开关电源测试的其中一个测试项目。那么要如何测试电压调整率呢?测试条件是什么呢? 什么是电压调整率? 电压调整率是指变压器某个绕组的空载电压和指定负载和功率因数…

[机缘参悟-110] :一个IT人对面具的理解:职业面具戴久了,就会忘记原本真实的自己,一个人是忠于职位,还是忠于内心?

目录 一、职业面具戴久了&#xff0c;就会忘记原本真实的自己 二、霸王别姬 三、没有对错&#xff0c;各走各路 3.1 程蝶衣&#xff1a;戏里戏外&#xff0c;忠于角色 3.2 段小楼&#xff1a;戏里戏外&#xff0c;角色分明 3.3 没有对错&#xff0c;各走各路 四、职场中…

网络库OKHTTP(2)面试题

序、慢慢来才是最快的方法。 背景 OkHttp 是一套处理 HTTP 网络请求的依赖库&#xff0c;由 Square 公司设计研发并开源&#xff0c;目前可以在 Java 和 Kotlin 中使用。对于 Android App 来说&#xff0c;OkHttp 现在几乎已经占据了所有的网络请求操作。 OKHttp源码官网 问1…

面向切面:AOP

文章目录 简介相关术语①横切关注点②通知&#xff08;增强&#xff09;③切面④目标⑤代理⑥连接点⑦切入点 场景模拟代理模式静态代理动态代理 基于注解的AOP&#xff08;重点&#xff09;准备工作各种通知切入点表达式语法重用切入点表达式获取通知的相关信息 环绕通知 切面…

用GDB调试程序的栈帧

2023年10月17日&#xff0c;周二晚上 目录 练习GDB栈帧调试功能的程序 GDB栈帧方面的指令 调试效果 练习GDB栈帧调试功能的程序 斐波那契数列 #include <iostream>int factorial(int n) {if (n < 1) {return 1;} else {return n * factorial(n - 1);} }int main(…

基于nodejs+vue学籍管理系统

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

C#中DataAdapter对象

目录 一、DataAdapter对象概述 二、Fill()方法填充数据集DataSet 1.举例 2.源码 3.生成效果 三、Update()方法 1.Update()方法更新数据源 2.设置数据库主键 3.源码 4.生成效果 一、DataAdapter对象概述 DataAdapter对象是一个数据适配器对象&#xff0c;是DataSet与…

说说对前端工程化的理解?

前端工程化是指将前端开发过程中的工具、流程和方法结合起来&#xff0c;提高开发效率、代码质量和团队协作的一种实践。涉及到多个方面&#xff1a; 包括代码管理、构建工具、自动化测试、性能优化、模块化开发等。 以下是前端工程化的主要内容和目标&#xff1a; 1&#xf…

【yolov8系列】yolov8的目标检测、实例分割、关节点估计的原理解析

1 YOLO时间线 这里简单列下yolo的发展时间线&#xff0c;对每个版本的提出有个时间概念。 2 yolov8 的简介 工程链接&#xff1a;https://github.com/ultralytics/ultralytics 2.1 yolov8的特点 采用了anchor free方式&#xff0c;去除了先验设置可能不佳带来的影响借鉴Genera…

nodejs基于vue小型企业银行账目管理系统

这就产生了以台式计算机为核心的管理信息系统在大规模的事务处理和对工作流的管理等方面的应用&#xff0c;在银行帐目管理之中的应用日益增加 且会出现信息的重复传递问题&#xff0c;因此该过程需要进行信息化,以利用计算机进行帐目管理。 3.1 银行帐目管理系统功能模块 …

【vue2高德地图api】03-完善展示页,并且调用poi搜索接口

系列文章目录 文章目录 系列文章目录前言一、编写页面内容样式1.1 html内容1.2 css内容解决报错 二、完善api接口变量方法1.data变量2. methods3. computed4. api接口方法 三、配置api接口方法创建map.jsgetParkList方法 移动端控制台插件四、编写components组件在main.js中引入…

【Leetcode】 416. 分割等和子集

给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集&#xff0c;使得两个子集的元素和相等。 示例 1&#xff1a; 输入&#xff1a;nums [1,5,11,5] 输出&#xff1a;true 解释&#xff1a;数组可以分割成 [1, 5, 5] 和 [11] 。 示例 2&…

跬智信息(Kyligence)成为信创工委会技术活动单位

近日&#xff0c;跬智信息经过层层筛选和评审&#xff0c;成功加入中国电子工业标准化技术协会信息技术应用创新工作委员会&#xff08;以下简称信创工委会&#xff09;&#xff0c;正式成为信创工委会技术活动单位。 中国电子工业标准化技术协会信息技术应用创新工作委员会成立…

UR构型的奇异点

关节5与关节4平行时&#xff0c;发生腕部奇异关节234共面时&#xff0c;发生肘部奇异关节56交点在关节12轴线组成的平面内时&#xff0c;发生肩部奇异 下面这段视频说明了UR构型机器人奇点的三种类型。 参考链接&#xff1a; https://www.mecademic.com/academic_articles/si…

.Git 仓库敏感信息泄露

Git介绍 Git是由林纳斯托瓦兹&#xff08;Linus Torvalds&#xff09;命名的&#xff0c;它来自英国俚语&#xff0c;意思是“混账”&#xff0c;Git是一个分布式版本控制软件&#xff0c;最初由林纳斯托瓦兹&#xff08;Linus Torvalds&#xff09;创作&#xff0c;于2005年以…