数组逆置方法总结

今天总结一下数组的逆置方法。这里列出两种方法,一种是循环迭代的方式:思路就是第一个和倒数第一个交换、第二个和倒数第二个交换...依次进行下去;另一种方式是递归:思路是设置首尾两指针,首指针每次递归加一,尾指针每次递归减一,当首尾指针相同时return,当首指针+1等于尾指针时交换首尾指针指向的元素,然后再返回,每次递归完成后要交换当前的首尾指针指向的元素。代码如下:


头文件:exchange.h


#ifndef _EXCHANGE_H_
#define _EXCHANGE_H_
#define change(x,y); \
	a[x] = a[x] + a[y]; \
	a[y] = a[x] - a[y]; \
	a[x] = a[x] - a[y];
#endif


源文件:ArrayReverse.cpp


#include <iostream>
#include "exchange.h"
using namespace std;
void reverseByRecursion(int a[], int start, int end)
{
	if (start == end)
	{
		return;
	}
	else if(start+1 == end){
		change(start, end);
		return;
	}
	else{
		reverseByRecursion(a, start+1, end-1);
		change(start, end);
	}
}

void reverseByIteration(int a[], int len)
{
	int i = 0, tmp = 0;
	for (i = 0; i < len / 2; ++i)
	{
		change(i, len-i-1);
	}
}

int main()
{
	int a[] = { 1, 2, 3, 4, 5, 9, 50, 23 };
	//reverseByIteration(a, sizeof(a) / sizeof(int));
	reverseByRecursion(a, 0, sizeof(a) / sizeof(int)-1);
	for (int i = 0; i<sizeof(a) / sizeof(int); i++)
		cout << a[i] << " ";
	system("PAUSE");
	return 0;
}


算法参考自:http://www.cnblogs.com/tinaluo/p/5267779.html

### 回答1: 可以定义一个函数,接收一个长度为10的整型数组作为参数,然后将数组中的数据逆置。可以使用两个指针,一个指向数组第一个元素,一个指向数组的最后一个元素,然后交换它们的值,再将指针向中间移动,直到它们相遇为止。代码如下: ```c void reverse(int arr[]) { int *p1 = arr, *p2 = arr + 9; while (p1 < p2) { int temp = *p1; *p1 = *p2; *p2 = temp; p1++; p2--; } } ``` 调用这个函数时,只需要传入一个长度为10的整型数组即可: ```c int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; reverse(arr); ``` 执行完这段代码后,数组中的数据就被逆置了。 ### 回答2: 题目要求定义一个函数,将10个单元的整型数组里的数据逆置。所谓逆置,就是将原数组元素顺序反转。 解题思路: 我们可以通过定义一个临时数组来实现对原数组逆置。 具体实现: 1.首先定义一个函数,函数的返回类型为void,函数名为reverse_array,函数参数为整型数组a和整型数组的长度length,代码如下: void reverse_array(int a[], int length){} 2.在函数内部定义一个临时数组temp,长度为length,用来存储逆置后的数组元素。 int temp[length]; 3.接着用for循环将原数组a的元素顺序倒序复制到temp数组中。 for(int i=length-1,j=0;i>=0;i--,j++){temp[j]=a[i];} 4.最后再用for循环将逆置后的temp数组的元素复制到原数组a中。 for(int i=0;i<length;i++){a[i]=temp[i];} 完整代码如下: void reverse_array(int a[], int length){ int temp[length]; for(int i=length-1,j=0;i>=0;i--,j++){temp[j]=a[i];} for(int i=0;i<length;i++){a[i]=temp[i];} } 调用该函数: 在main函数中调用reverse_array函数对数组进行逆置。 int main() { int arr[10] = {1,2,3,4,5,6,7,8,9,10}; printf("原数组:\n"); for(int i=0;i<10;i++){ printf("%d ",arr[i]); } printf("\n逆置后的数组:\n"); reverse_array(arr,10); //调用reverse_array函数进行逆置 for(int i=0;i<10;i++){ printf("%d ",arr[i]); } return 0; } 运行结果如下: 原数组: 1 2 3 4 5 6 7 8 9 10 逆置后的数组: 10 9 8 7 6 5 4 3 2 1 至此,该函数的定义和调用都已完成。 ### 回答3: 题目需求:定义一个函数,将10个单元的整型数组里的数据逆置。 解题思路: 逆置一个数组就是将数组中的元素从后往前排,交换位置。 定义一个函数reverseArray,其中传入一个长度为10的整型数组arr,函数内部使用循环的方式将数组arr从两侧开始逐个元素交换,直到数组中心。 代码实现: ```c void reverseArray(int arr[], int length) { // 定义函数reverseArray,传入整型数组arr和数组长度length int temp; // 定义临时变量temp for(int i = 0; i < length / 2; i++) { // 循环遍历数组中的前一半元素 temp = arr[i]; // 使用temp缓存当前元素值 arr[i] = arr[length - i - 1]; // 交换当前元素和对称位置的元素 arr[length - i - 1] = temp; // 将较大位置的元素值存入对称位置 } } ``` 注:传入函数的数组arr需是一个长度为10的数组。 函数使用: 可在主函数中调用函数reverseArray,并向其传入一个长度为10的整型数组arr。具体实现如下: ```c int main() { int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; // 定义一个长度为10的整型数组arr reverseArray(arr, 10); // 将数组逆置 for (int i = 0; i < 10; i++) { // 循环遍历逆置后的数组arr printf("%d ", arr[i]); // 打印数组arr中的元素 } return 0; // 完成逆置操作,返回0 } ``` 解释:在主函数中,先定义一个长度为10,元素值为1~10的整型数组arr,然后将数组arr传入函数reverseArray中,对数组进行逆置操作;最后使用循环遍历逆置后的数组arr,并将数组中的元素值打印输出。输出结果为:10 9 8 7 6 5 4 3 2 1。 总结: 对于这道题目,需要我们掌握定义函数和数组逆置方法,并在主函数中调用所定义的函数进行运算。同时,需要注意在定义函数时,传入的数组arr的长度需指定为10。这样,才能使本题的代码实现正确。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值