//case2:创建一个整形数组,完成对数组的操作
// 实现函数init() 初始化数组为全0
// 实现print() 打印数组的每个元素
// 实现reverse() 函数完成数组元素的逆置。
// 要求:自己设计以上函数的参数,返回值。
#include <stdio.h>
//初始化数组全为0
void init(int arr2[],int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
arr2[i] = 0;
//arr[i] = i;//初始化数组为1-9
}
}
//打印数组
void print(int arr2[],int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr2[i]);
}
printf("\n");
}
//数组元素的逆置
void reverse(int arr2[], int sz)
{
int left = 0;
int right = sz - 1;
if (left < right)
{
int tmp = arr2[left];
arr2[left] = arr2[right];
arr2[right] = tmp;
left++;
right--;
}
}
int main()
{
//创建一个数组
int arr2[] = { 1,2,3,4,5,6,7,8,9};//意味着三行四列
int sz = sizeof(arr2) / sizeof(arr2[0]);
printf("原数组:\n");
print(arr2,sz);
printf("逆置数组:\n");
reverse(arr2,sz);
print(arr2, sz);
printf("初始化数组:\n");
init(arr2, sz);
print(arr2, sz);
return 0;
}
优化
case2.1---添加清空数组函数
初始化数组
void Init(int arr[], int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
arr[i] = i;
}
}
清空数组
void Empty(int arr[], int sz)
{
memset(arr, 0, sz*sizeof(arr[0]));
}
逆置数组
void Reverse(int arr[], int sz)
{
int left = 0;
int right = sz - 1;
while (left < right)
{
int tmp = arr[left];
arr[left] = arr[right];
arr[right] = tmp;
left++;
right--;
}
}
打印数组
void Print(int arr[], int sz)
{
int i = 0;
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
printf("\n");
}
int main()
{
int arr[10] = { 1, 3, 5, 7, 9, 11, 13, 15, 17, 19 };
int sz = sizeof(arr) / sizeof(arr[10]);
int i = 0;
printf("原数组:\n");
Print(arr, sz);
Init(arr, sz);
printf("初始化数组:\n");
Print(arr, sz);
Reverse(arr, sz);
printf("逆序数组:\n");
Print(arr, sz);
Empty(arr, sz);
printf("清空数组:\n");
Print(arr, sz);
return 0;
}