【03】逆序数组

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

一、逆序函数是什么?

二、逆序函数原码

1.直接逆序

2.创建临时数组逆序

三、结言


💥一、逆序函数是什么?

示例:输入1 4 7 9 3

输出:3 9 7 4 1

通俗来说就是将数组一行数据倒着打印。

✨二、逆序函数原码

🥳1.直接逆序

思路:

1.利用scanf与for循环获取多组数据;

2.用left与right两个变量进行左右交换,交换完左边向右靠近,右边向左边靠近,继续交换,直到 left>=right为止;

图示如下:

复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
void reverse()
{
	int i = 0;
	int j = 0;
	int tmp = 0;
	printf("请输入你要输入数的个数:");
	scanf("%d", &j);
	int arr[] = { 0 };//注意这里数组没有确定个数

	for (i = 0; i < j; i++)
	{
		scanf("%d", &arr[i]);
	}

	int left = 0;
	int right = j-1;
	while (left <= right)//利用左右下标逐渐向中间靠近
	{
		tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		left++;
		right--;
	}
	for(i = 0;i <=j-1;i++)
	{ 
		printf("%d\n",arr[i]);
	}


}
int main()
{
	reverse();
	return 0;
}

由于上述代码利用数组存储个数时没有确定数组个数就会导致如下情况:

正确做法:

int arr[10] = {0}//允许输入十个数以内的逆序,也可换成100或者其他

修改后代码如下:

复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
void reverse()
{
	int i = 0;
	int j = 0;
	int tmp = 0;
	printf("请输入你要输入数的个数(<10):");
	scanf("%d", &j);
	int arr[10] = { 0 };


	for (i = 0; i < j; i++)
	{
		scanf("%d", &arr[i]);
	}

	int left = 0;
	int right = j-1;
	while (left <= right)//利用左右下标逐渐向中间靠近
	{
		tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
		left++;
		right--;
	}
	for(i = 0;i <=j-1;i++)
	{ 
		printf("%d\n",arr[i]);
	}


}
int main()
{
	reverse();
	return 0;
}

🥳🥳2.创建临时数组逆序

思路:

将数组的数从后往前放入到临时创建的数组中

复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
void reverse()
{
	int i = 0;
	int j = 0;
	int tmp = 0;
	printf("请输入你要输入数的个数(<10):");
	scanf("%d", &j);
	int arr[10] = { 0 };


	for (i = 0; i < j; i++)
	{
		scanf("%d", &arr[i]);
	}


		//直接逆序
		//tmp = arr[j];//先将最后一个数存储起来
		//for (i = j; i > 0; i--)
		//{
		//	arr[j] = arr[j - 1];//循环逆转
		//}
		//arr[0] = tmp;//将第一个储存最后一个数完成逆转

	//创建临时数组实现逆序
	int tem[10] = { 0 };//创建临时数组
	for (i = 0; i < j; i++)
	{
		tem[i] = arr[j-i- 1];//将arr数组后面的数存储到tem数组前面
	}


	for(i = 0;i <=j-1;i++)//打印逆序后的数组
	{ 
		printf("%d\n",arr[i]);
	}


}
int main()
{
	reverse();
	return 0;
}

🎉三、结言

以上就是C语言实现逆序数组完整实现啦~🌹🌹🌹土土这里用了两种方法一种是直接发利用左右两个指针来遍历,另一种是创建临时数组来将原来的数组中的数从后往前放置,两种方法各有优缺点哦~如果有什么问题,欢迎打在评论区或者私法给我哦~💖💖

相关推荐
重生之我是Java开发战士1 分钟前
【数据结构】AVL树解析
数据结构·算法
小π军4 分钟前
STL之multiset 常见API介绍
数据结构·c++·算法
研究点啥好呢6 分钟前
Momenta算法工程师面试题精选:10道高频考题+答案解析
人工智能·算法·求职招聘·面试笔试
Resistance丶未来6 分钟前
DeepSeek-V4 新手快速上手指南
数据结构·python·gpt·算法·机器学习·claude·claude 4.6
无限进步_15 分钟前
【C++】寻找数组中出现次数超过一半的数字:三种解法深度剖析
开发语言·c++·git·算法·leetcode·github·visual studio
comli_cn17 分钟前
HMM算法
线性代数·算法
Via_Neo18 分钟前
Nim Game
算法
人道领域24 分钟前
【LeetCode刷题日记】150.逆波兰表达式求值
java·数据结构·算法·leetcode
蓝桉~MLGT27 分钟前
中级软考(软件工程师)算法特辑——常考的六大基础排序算法
java·算法·排序算法
minji...28 分钟前
Linux 网络套接字编程(五)TCP 回声服务器的实现(单进程(单线程)/多进程/多线程/线程池四个版本)
linux·服务器·开发语言·网络·c++·tcp/ip·算法