使用C语言函数对数组进行操作

        前言

        在我们了解数组和函数之后,我们对数组和函数进行结合,之后完成一些操作吧

        题目描述

        杰克想将函数与数组结合进行一些操作,以下是他想要达到的效果,请你帮帮他吧!

        创建一个整型数组,完成对数组的操作

        1.实现函数init(),初始化数组全为0。

        2.实现函数print(),打印数组每个元素。

        3.实现函数reverse(),完成数组元素的逆置。

        输入描述:

        无

        输出描述:

        三行,第一行打印数组每个元素,第二行逆置,第三行初始化

        题目分析

        我们来分析一下这道题目,我们需要先定义一个数组,但是题目中没有要求,我们就定义数组arr={5,2,0,1,3,1,4},哎,这里也和代码浪漫一下吧,博主也只能如此了。

        我们看看第一条要求,我们需要对数组进行初始化,使用init函数实现,在这个时候,我们需要想到初始化数组的时候我们需要遍历数组之后将0赋予数组中的元素,所以这里我们需要for循环来实现,但是我们不知道数组中的元素个数啊,我们需要使用sizeof操作符来实现对我们数组元素的计算,如果有小伙伴对sizeof操作符的使用方法不太理解可以翻翻博主之前的博客哦。

        第二条要求是打印数组中的元素,这个就简单了,我们使用for循环直接打印就好啦。

        第三条要求我们完成数组元素的逆置,这里我们就需要动点脑筋了,我们需要置换数组中的元素,再来一遍,上图!!!

        

        如图所示3步走,之后就可以逆置得到我们想要的数组了,话不多说了,上代码

        代码展示

        

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
//初始化函数
void init(int arr[], int sz)
{
	int i;
	for (i = 0;i < sz;i++)
	{
		arr[i]=0;
	}
}
//输出函数
void print(int arr[], int sz)
{
	int i;
	for (i = 0;i < sz;i++)
	{
		printf("%d", arr[i]);
	}
	printf("\n");
}
//逆置函数
void reserve(int arr[], int left,int right)
{
    //注意,这里我们应该先判断之后再置换,不能等到置换结束之后再判断,这样会导致程序bug
	if (left < right)
	{
		char tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		reserve(arr, left + 1, right - 1);
	}
}
int main()
{
	int arr[] = { 5,2,0,1,3,1,4 };
    //计算数组中元素个数
	int sz = sizeof(arr) / sizeof arr[0];
	int right = sz - 1;
	int left = 0;
	print(arr, sz);
	reserve(arr, left,right);
	print(arr, sz);
	init(arr, sz);
	print(arr, sz);
	return 0;
}

        代码解析

        我们先来看看主函数,我们定义数组,之后计算数组中元素个数,之后我们注意,在我们传参的时候在init函数和print函数中只需要将数组的首地址和数组中元素个数传输过去,但是在逆置函数reverse中我们需要将数组元素的左右下标定义好之后进行传参。

        注意啦,在这里我们使用reserve函数的时候我们需要先判断数组中元素左下标是否小于右下标,我们不能将判断放在置换之后,这样的话会发生一个问题,什么问题呢,就是当我们输入的数组元素个数是偶数的时候,在最后一步会发生两次置换,以520131为例,如果我们输入数组中元素是520131的话,置换后的结果就会变为130125,我们会发现01的位置没有改变,这里其实是发生了两次置换,当我们数组中元素置换为131025的时候中间元素再次进行了置换,这里我们就会发现,唉,这个代码是有问题的。

        

        修正:

        

        

        运行结果

        

        

        兄弟们,今天就到这里喽,大家如果有不了解的问题,评论区我随时都在哦,欢迎大家评论区留言嘞!!!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Taro框架中的H5 模板基本搭建

1.H5 模板框架的搭建 一个h5 的基本框架的搭建 基础template 阿乐/H5 Taro 的基础模板

人民网至顶科技:《开启智能新时代:2024中国AI大模型产业发展报告发布》

​3月26日&#xff0c;人民网财经研究院与至顶科技联合发布《开启智能新时代&#xff1a;2024年中国AI大模型产业发展报告》。该报告针对AI大模型产业发展背景、产业发展现状、典型案例、挑战及未来趋势等方面进行了系统全面的梳理&#xff0c;为政府部门、行业从业者以及社会公…

推荐一款自动化测试神器---Katalon Studio

Katalon Studio介绍 Katalon Studio 是一款在网页应用、移动和网页服务方面功能强大的自动化测试解决方案。基于 Selenium 和 Appium框架&#xff0c;Katalon Studio集成了这些框架在软件自动化方面的优点。这个工具支持不同层次的测试技能集。非程序员也可以快速上手一个自动…

5分钟了解清楚【osgb】格式的倾斜摄影数据metadata.xml有几种规范

数据格式同样都是osgb&#xff0c;不同软件生产的&#xff0c;建模是参数不一样&#xff0c;还是有很大区别的。尤其在应用阶段。 本文从建模软件、数据组织结构、metadata.xml&#xff08;投影信息&#xff09;、应用几个方面进行了经验性总结。不论您是初步开始建模&#xf…

Windows Server 2008添加Web服务器(IIS)、WebDAV服务、网络负载均衡

一、Windows Server 2008添加Web服务器&#xff08;IIS&#xff09; &#xff08;1&#xff09;添加角色&#xff0c;搭建web服务器&#xff08;IIS&#xff09; &#xff08;2&#xff09;添加网站&#xff0c;关闭默认网页&#xff0c;添加默认文档 在客户端浏览器输入服务器…

力扣LCR143---子结构判定(先序递归、Java、中等题)

题目描述&#xff1a; 给定两棵二叉树 tree1 和 tree2&#xff0c;判断 tree2 是否以 tree1 的某个节点为根的子树具有 相同的结构和节点值 。 注意&#xff0c;空树 不会是以 tree1 的某个节点为根的子树具有 相同的结构和节点值 。 示例 1&#xff1a; 输入&#xff1a;tree…

你真的了解区块链游戏吗?

随着区块链技术的不断发展和普及&#xff0c;越来越多的人开始关注区块链游戏这一新兴领域。然而&#xff0c;很多人对于区块链游戏的了解仅限于一些表面的概念和特点&#xff0c;真正深入了解的人并不多。那么&#xff0c;你真的了解区块链游戏吗&#xff1f; 首先&#xff0…

12.java openCV4.x 入门-HighGui之图像窗口显示

专栏简介 &#x1f492;个人主页 &#x1f4f0;专栏目录 点击上方查看更多内容 &#x1f4d6;心灵鸡汤&#x1f4d6;我们唯一拥有的就是今天&#xff0c;唯一能把握的也是今天建议把本文当作笔记来看&#xff0c;据说专栏目录里面有相应视频&#x1f92b; &#x1f9ed;文…

【每日刷题】Day7

【每日刷题】Day7 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; 1. 206. 反转链表 - 力扣&#xff08;LeetCode&#xff09; 2. 203. 移除链表元素 - 力扣&#xff08;…

【java数据结构-二叉树详解(下)带你手撕对称二叉树等难题(附题目链接)】

&#x1f308;个人主页&#xff1a;努力学编程’ ⛅个人推荐&#xff1a;基于java提供的ArrayList实现的扑克牌游戏 |C贪吃蛇详解 ⚡学好数据结构&#xff0c;刷题刻不容缓&#xff1a;点击一起刷题 &#x1f319;心灵鸡汤&#xff1a;总有人要赢&#xff0c;为什么不能是我呢 …

正则问题【蓝桥杯】/dfs

正则问题 dfs 刚开始用的是栈&#xff0c;没有想到dfs… #include<iostream> #include<stack> using namespace std; string s; int pos; int dfs() {//ans表示到当前位置最多的x数目//num表示暂存的x数目int num0,ans0;while(pos<s.size()){if(s[pos](){pos;…

蓝桥杯-【二分】肖恩的苹果林

思路:有点类似于找最大值的最小化。 代码及解析 常规的模板引用40% #include <bits/stdc.h> using namespace std; #define ll long long const ll N1e53; ll a[N]; ll m,n; ll chack(ll mid) {int res1,last0;for(int i1;i<n;i){ if(a[i]-a[last]>mid){res;las…

秋招算法刷题6

20240408 1.两数之和 &#xff08;时间复杂度是O&#xff08;n的平方&#xff09;&#xff09; public int[] twoSum(int[] nums, int target){int nnums.length; for(int i0;i<n;i){ for(int j1;j<n;j){ if(nums[i][j]target){ …

大型央国企“信创化”与数字化转型建设思路

一、央国企信创化与数字化转型时代背景 1、信创概念普及&#xff1a; 信创&#xff0c;即“信息技术应用创新”。是我国自主信息产业聚焦的核心&#xff0c;旨在通过对IT硬件、软件等各个环节的重构&#xff0c;基于我国自有IT底层架构和标准&#xff0c;形成自有开放生态&am…

使用Mac自带终端进行远程ssh连接Linux服务器

废话不多说&#xff0c;直接上图 好吧&#xff0c;我承认我是多此一举&#xff0c;脱裤子放pi了&#xff0c;其实只需要在终端输入一行命令就可以了&#xff08;呜呜&#xff5e;&#xff09; ssh rootip -p 22 需要注意的是&#xff0c;命令里的ip地址同样要替换成你自己的服…

【并发】第四篇 AtomicInteger原子操作

导航 一. 简介二. 源码分析三. 原子操作原理三. 实际用途1. 标志位2. 唯一标识生成器3. 计数器一. 简介 AtomicInteger是Java中提供的一种线程安全的原子操作类,用来实现对整数类型的原子操作。它可以在多线程环境下保证对整数的原子性操作,而不需要使用synchronized关键字或…

分类预测 | Matlab实现CPO-LSSVM冠豪猪算法优化最小二乘支持向量机数据分类预测

分类预测 | Matlab实现CPO-LSSVM冠豪猪算法优化最小二乘支持向量机数据分类预测 目录 分类预测 | Matlab实现CPO-LSSVM冠豪猪算法优化最小二乘支持向量机数据分类预测分类效果基本介绍程序设计参考资料 分类效果 基本介绍 1.Matlab实现CPO-LSSVM冠豪猪算法优化最小二乘支持向量…

抖店运营没有销量?想要快速拉高,产品部分一定做好!

大家好&#xff0c;我是电商小布。 我们开通抖音小店&#xff0c;运营店铺的最终目的&#xff0c;都是为了顺利实现转化。 但是有的小伙伴在开店运营之后&#xff0c;发现自己的店铺在销量上并没有什么起色在。 出现这个情况是怎么回事呢&#xff1f; 之前就有给大家说过&a…

寻找伙伴/拓展业务/开拓市场 2024CBTC上海国际储能展,为您提供海量商机!

在全球能源转型的背景下&#xff0c;电力市场正在经历一场前所未有的大变革&#xff0c;以储能为核心的新型电力系统建设正成为能源转型的重要抓手&#xff0c;给电力及新能源行业带来更多机遇。 由湖南省电池产业协会、中国设备管理协会、沪粤储能产业联盟、深圳国际投融资商…