创建一个数组, 实现函数init()初始化数组、实现empty()清空数组、实现reverse()函数完成数组元素的逆置。

一、描述:

创建一个数组,
实现函数init()初始化数组、
实现empty()清空数组、
实现reverse()函数完成数组元素的逆置。
要求:自己设计函数的参数,返回值。

二、分析:

1、清空数组。

memset是初始化函数。作用是将内存中指定内容,全部设置为特定值。
void* memset(void *s, int ch, size_t n);
函数解释:
将s中当前位置后面的n个字节用 ch 替换并返回 s 。
例如:
把一个int a[10]清零,一定是 memset(a,0,sizeof (a[0]) * 10);
memset 在进行内存设置时,以字节为基本单位。

2、逆置数组:

只需求len/2即可。原因如下:
在这里插入图片描述

三、程序:

#include<stdio.h>
#include<windows.h>
#include<string.h>
void Init(int a[], int len){            //初始化数组
	printf("初始化数组:");
	int i = 0;
	for (i = 0; i < len; i++){
		a[i] = i;
		printf("%2d", a[i]);
	}
	printf("\n");
}

void Reverse(int a[], int len){       //逆置数组
	printf("逆置数组:   ");
	int i = 0;
	for (i = 0; i < len / 2; i++){
		int temp = a[i];
		a[i] = a[len - 1 - i];
		a[len - 1 - i] = temp;
		//方法二(异或方法)
		//m^m=0,m^0=m
		//a[i] = a[i] ^ a[len - 1 - i];
		//a[len - 1 - i] = a[i] ^ a[len - 1 - i];  
		//a[i] = a[i] ^ a[len - 1 - i];
	}
	for (i = 0; i < len; i++){
		printf("%2d", a[i]);
	}
	printf("\n");
}

void Empty(int a[], int len){             清空数组
	printf("清空数组:  ");
	memset(a, 0, sizeof(a[0])*len);
	int i = 0;
	for (i = 0; i < len; i++){
		printf("%2d", a[i]);
	}
	printf("\n");
}
 
int main(){
	int i = 0;
	int a[ ] = {0,2,4,6,8,1,3,5,7,9};
	int len = sizeof(a) / sizeof(a[0]);
	printf("原数组:    ");
	for (i = 0; i < len; i++){
		printf("%2d", a[i]);
	}
	printf("\n");
	Init(a, len);
	Reverse(a, len);
	Empty(a, len);
	system("pause");
	return 0;
}

四、运行结果:

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来设计一个函数模板reverse实现对一个一维数组元素的逆序操作。可以使用C++标准库中的algorithm头文件中的reverse函数,也可以手动编写一个reverse函数。 方法一:使用algorithm头文件中的reverse函数 ``` #include <algorithm> using namespace std; template<typename T> void reverse(T arr[], int size){ reverse(arr, arr + size); } ``` 这个函数模板中,使用了algorithm头文件中的reverse函数,将数组arr中的元素进行逆序操作。需要注意的是,这里的reverse函数需要两个参数,分别是数组的起始地址和终止地址,因此需要使用arr和arr+size来作为函数的参数。 方法二:手动编写一个reverse函数 ``` template<typename T> void reverse(T arr[], int size){ for(int i=0; i<size/2; i++){ T temp = arr[i]; arr[i] = arr[size-i-1]; arr[size-i-1] = temp; } } ``` 这个函数模板中,使用了一个for循环来实现逆序操作。循环次数为数组大小的一半,每次循环都交换数组中对称的两个元素,直到循环结束为止。 在主函数中,我们可以使用这个函数模板对一个一维数组进行逆序操作,如下所示: ``` int main(){ int arr1[] = {1, 2, 3, 4, 5}; char arr2[] = {'a', 'b', 'c', 'd', 'e'}; reverse(arr1, 5); // 对int类型的数组进行逆序操作 for(int i=0; i<5; i++) cout << arr1[i] << " "; // 输出:5 4 3 2 1 cout << endl; reverse(arr2, 5); // 对char类型的数组进行逆序操作 for(int i=0; i<5; i++) cout << arr2[i] << " "; // 输出:e d c b a cout << endl; return 0; } ``` 在这个示例中,我们分别对一个int类型的数组和一个char类型的数组进行了逆序操作,并输出了结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值