用c语言编程:本题要求编写程序,将一维数组中的元素重新按逆序存放在原数组中(只定义一个数组)。 输入样例: 9 3 2 1 4 5 7 6 10 9 输出样例: 9 10 6 7 5 4 1 2 3 输入样例: 10 3 2 1 4 5 8 7 6 10 9 输出样例: 9 10 6 7 8 5 4 1 2 3
时间: 2023-12-18 22:02:42 浏览: 76
以下是用C语言编写的实现代码:
```c
#include <stdio.h>
#define MAX 100
int main()
{
int a[MAX], n, i, t;
scanf("%d", &n);
for (i = 0; i < n; i++)
scanf("%d", &a[i]);
for (i = 0; i < n / 2; i++) {
t = a[i];
a[i] = a[n - i - 1];
a[n - i - 1] = t;
}
for (i = 0; i < n; i++)
printf("%d ", a[i]);
printf("\n");
return 0;
}
```
这里我们使用了一个简单的循环来逆序存储数组中的元素。对于输入的数组,我们遍历它的前一半,将其第i个元素与第n-i-1个元素交换。最后输出逆序后的数组即可。
相关问题
用c语言数组编写程序将一维数组中的元素重新按逆序存放在原数组中,且只定义一个数组
以下是用C语言实现将一维数组中的元素重新按逆序存放在原数组中的程序:
```c
#include <stdio.h>
#define MAX_SIZE 100
int main()
{
int arr[MAX_SIZE], n, i, temp;
printf("Enter the size of the array: ");
scanf("%d", &n);
printf("Enter the elements of the array:\n");
for(i=0; i<n; i++)
{
scanf("%d", &arr[i]);
}
// Reversing the array
for(i=0; i<n/2; i++)
{
temp = arr[i];
arr[i] = arr[n-1-i];
arr[n-1-i] = temp;
}
printf("The array after reversing is:\n");
for(i=0; i<n; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
```
在这个程序中,我们使用了一个名为`arr`的一维整型数组,它的大小为`MAX_SIZE`。用户输入数组的大小和元素,然后程序将数组按逆序重新排列,最后输出排列后的数组。
我们使用一个`for`循环来遍历数组,并使用一个`temp`变量来交换数组的元素,从而实现数组的逆序排列。
本题要求编写程序,将一维数组中的元素重新按逆序存放在原数组中(只定义一个数组)的C语言
以下是将一维数组按逆序重新存放的C语言程序:
```c
#include <stdio.h>
void reverseArray(int arr[], int size) {
int temp, start = 0, end = size - 1;
while (start < end) {
temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
start++;
end--;
}
}
int main() {
int arr[] = {1, 2, 3, 4, 5};
int size = sizeof(arr)/sizeof(arr[0]);
printf("Original array: ");
for (int i = 0; i < size; i++)
printf("%d ", arr[i]);
reverseArray(arr, size);
printf("\nReversed array: ");
for (int i = 0; i < size; i++)
printf("%d ", arr[i]);
return 0;
}
```
输出结果为:
```
Original array: 1 2 3 4 5
Reversed array: 5 4 3 2 1
```
在上面的代码中,我们定义了一个函数 `reverseArray`,该函数接受一个整型数组和数组的大小作为参数。函数使用两个指针 `start` 和 `end` 来交换数组的元素,直到数组被完全翻转。在主函数中,我们调用了 `reverseArray` 函数,将数组元素翻转,并在屏幕上打印原始数组和翻转后的数组。
阅读全文