使用函数实现数组操作
创建一个整形数组,完成对数组的操作
1.实现函数init() 初始化数组为全0
2.实现print() 打印数组的每个元素
3.实现reverse() 函数完成数组元素的逆置。
要求:自己设计以上函数的参数,返回值。
首先,我们先简单写前两个操作。
#include<stdio.h>
void Initarr(int arr[], int len, int var)
{
for (int i = 0; i < len; i++)
{
arr[i] = var;
}
}
void Print(int arr[], int len)
{
for (int i = 0; i < len; i++)
{
printf("%d ", arr[i]);
}
}
int main()
{
int arr[10] = { 1 };
int len = sizeof(arr) / sizeof(arr[0]);
Initarr(arr, len, 0);
Print(arr, len);
return 0;
我们不妨思考一下,我们是否可以对数组的初始化从0到9都进行一遍,由此,我们尝试写一写。
会发现,结果仍然是9.
也就是
第一次 i=0 把len个值都初始化为了0
第二次 i=1 把len个值都初始化为了1
。。。。。。
我们的目标是把它初始化为0-9之间所有的数字
方案
首先去掉Initarr函数中的循环
void Initarr(int arr[], int len, int var)
{
arr[i] = var;
}
```然后发现,这里的i未定义
把len改为i,i=0即0下标设置为val
void Initarr(int arr[], int i, int var)
{
arr[i] = var;
}
也就是
void Initarr(int arr[], int i, int var)
{
arr[i] = var;
}
void Print(int arr[], int len)
{
for (int i = 0; i < len; i++)
{
printf("%d ", arr[i]);
}
}
int main()
{
int arr[10] = { 1 };
int len = sizeof(arr) / sizeof(arr[0]);
for (int i = 0; i < len; i++)
{
Initarr(arr, len, i);
}
Print(arr, len);
return 0;
}
len的值是10,Initarr函数的参数改了,那么函数调用内的参数的len也得改
否则会报错
void Initarr(int arr[], int i, int var)
{
arr[i] = var;
}
void Print(int arr[], int len)
{
for (int i = 0; i < len; i++)
{
printf("%d ", arr[i]);
}
}
int main()
{
int arr[10] = { 1 };
int len = sizeof(arr) / sizeof(arr[0]);
for (int i = 0; i < len; i++)
{
Initarr(arr, i, i);
}
Print(arr, len);
return 0;
}
我们就成功的将其初始化为0-9.
val也可以改为i
void Initarr(int arr[], int i,int i)
{
arr[i] = i;
}
但这样i就重定义了,因此保留一个即可。
void Initarr(int arr[], int i)
{
arr[i] = i;
}
扩展思考后,我们来解决第3个问题
实现reverse() 函数完成数组元素的逆置。
如图
i指向第一个元素,j指向最后一个元素
逆置,1和5要换
创建一个临时变量
接着
接着 i+ j-
2和4换
最后i和j相遇
分析完毕
由此,我们可以写代码了
void Reverse(int arr[], int len)
{
int i = 0;
int j = len - 1;
while (i < j)
{
int tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
i++;
j--;
}
}
可以这样
#include<stdio.h>
void Initarr(int arr[], int len, int i)
{
arr[i] = i;
}
void Print(int arr[], int len)
{
for (int i = 0; i < len; i++)
{
printf("%d ", arr[i]);
}
printf("\n");
}
void Reverse(int arr[], int len)
{
int i = 0;
int j = len - 1;
while (i < j)
{
int tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
i++;
j--;
}
}
int main()
{
int arr[10] = { 1 };
int len = sizeof(arr) / sizeof(arr[0]);
for (int i = 0; i < len; i++)
{
Initarr(arr, len, i);
}
Print(arr, len);
Reverse(arr, len);
Print(arr, len);
return 0;
}
也可以把len改了
最终完成。