C语言代码展示:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define max 10
//void reverse(sqlist L);
typedef struct sum
{
int data[max];
int length;
}sqlist,*p;//p 等价于 struct sum
void reverse(sqlist* L)
{
//sqlist L;
int temp;
for (int i = 0; i <(*L).length/2; i++)
{
temp = (*L).data[i];
(*L).data[i] = (*L).data[(*L).length -i-1];
(*L).data[(*L).length -i-1] = temp;
}
}
int main()
{
sqlist L = { {1,2,3,5,6,7,8,9},8 };
for (int i = 0; i < L.length; i++)
{
printf("%2d", L.data[i]);
}
printf("\n");
reverse(&L);
for (int j = 0; j < L.length; j++)
{
printf("%2d", L.data[j]);
}
printf("\n");
system("pause");
return 0;
}
C++代码展示:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define max 10
//void reverse(sqlist L);
typedef struct sum
{
int data[max];
int length;
}sqlist,*p;//p 等价于 struct sum
void reverse(sqlist &L)
{
//sqlist L;
int temp;
for (int i = 0; i <L.length/2; i++)
{
temp = L.data[i];
L.data[i] = L.data[L.length -i-1];
L.data[L.length -i-1] = temp;
}
}
int main()
{
sqlist L = { {1,2,3,5,6,7,8,9},8 };
for (int i = 0; i < L.length; i++)
{
printf("%2d", L.data[i]);
}
printf("\n");
reverse(L);
for (int j = 0; j < L.length; j++)
{
printf("%2d", L.data[j]);
}
printf("\n");
system("pause");
return 0;
}
- 将main函数中的 L 替换为 &L
- 将调用函数 reverse 中的 &L 全部替换为 *L 并且在必要时加上()
最终都能实现将所有的元素逆置
实现效果:

这篇博客展示了如何使用C和C++语言编写函数来实现数组元素的反转。代码中定义了一个结构体`sqlist`,包含一个整型数组和长度属性,并提供了`reverse`函数,通过遍历数组的一半并交换首尾元素来达到反转目的。在主函数`main`中创建了一个`sqlist`实例并调用`reverse`函数,最后打印出反转后的数组元素。
689

被折叠的 条评论
为什么被折叠?



