用c语言将数组的元素逆序存储。例如,数组a中的元素为1、3、2、4、6、5、9、8,逆序后为8、9、5、6、4、2、3、1。
时间: 2023-06-06 20:08:37 浏览: 254
可以这么实现:
``` c
#include <stdio.h>
#define LEN 8 // 数组长度
int main()
{
int a[LEN] = {1, 3, 2, 4, 6, 5, 9, 8};
int i, tmp;
for (i = 0; i < LEN / 2; ++i) {
tmp = a[i];
a[i] = a[LEN-1-i];
a[LEN-1-i] = tmp;
}
for (i = 0; i < LEN; ++i) {
printf("%d ", a[i]);
}
printf("\n");
return 0;
}
```
输出结果:
```
8 9 5 6 4 2 3 1
```
相关问题
c语言将数组的元素逆序输出
可以使用循环将数组中的元素逆序输出,具体代码如下:
```c
#include <stdio.h>
int main() {
int arr[5] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
for (int i = n - 1; i >= 0; i--) {
printf("%d ", arr[i]);
}
return 0;
}
```
输出结果为:`5 4 3 2 1`。
首先,定义了一个包含5个元素的整型数组`arr`,然后计算数组的长度,即元素个数,用变量`n`存储。接着,使用循环从数组的最后一个元素开始,倒序输出每个元素。其中,`printf`函数用来打印每个元素。循环的条件是`i >= 0`,即从最后一个元素一直循环到第一个元素。
c语言编写一个函数 Inverse0,实现将字符数组中的字符串逆序存放的功能。用数组a存放逆序存放前的数组元素,用数组b存放逆序存放后的数组元素。
好的,以下是C语言实现的代码:
```c
void Inverse0(char* str) {
char a[1000], b[1000];
int len = strlen(str);
for (int i = 0; i < len; i++) {
a[i] = str[i];
}
for (int i = 0; i < len; i++) {
b[i] = a[len - i - 1];
}
for (int i = 0; i < len; i++) {
str[i] = b[i];
}
}
```
以上代码中,我们先将原始字符串按照顺序存储到数组a中,然后再将数组a中的元素按照相反的顺序存储到数组b中,最后再将数组b中的元素按照顺序存储回原始字符串中,即可实现字符串逆序存放的功能。
请注意,由于我们使用了数组a和数组b,因此需要定义一个足够大的数组来存储字符串,以上代码中我们定义了大小为1000的数组。如果您的字符串比较长,可能需要调整数组的大小。
阅读全文