用键盘上输入n(n<=20)个整数存入一维数组,用指针变量表示数组元素的方式将其逆序存放,然后输出。注意,实现该算法时不允许再定义数组。在c语言中
时间: 2024-02-12 11:06:05 浏览: 113
下面是实现该算法的C语言代码:
```c
#include <stdio.h>
int main()
{
int n, *p, temp;
int a[20];
printf("请输入n(n<=20):");
scanf("%d", &n);
printf("请输入%d个整数:", n);
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
}
p = a; // 指针p指向a[0]
for (int i = 0; i < n / 2; i++) {
temp = *(p + i); // 交换a[i]和a[n-i-1]
*(p + i) = *(p + n - i - 1);
*(p + n - i - 1) = temp;
}
printf("逆序存放后的数组为:");
for (int i = 0; i < n; i++) {
printf("%d ", *(p + i));
}
return 0;
}
```
在这个程序中,我们使用了指针p来表示数组元素,而没有再定义一个数组。在逆序存放数组元素时,我们使用了指针的算术运算,即通过p+i来访问第i个元素。最后,我们再次使用指针p来输出逆序存放后的数组元素。
相关问题
输入n(不大于20)个整数存入一维数组,用指针变量处理数组元素的方式将其逆序存放后输出。n从键盘输入。
下面是一个示例代码:
```c
#include <stdio.h>
int main() {
int n, arr[20], *p = arr; // 定义数组和指针变量
printf("Enter the number of integers (not greater than 20): ");
scanf("%d", &n);
printf("Enter the integers: ");
for (int i = 0; i < n; i++) {
scanf("%d", p + i); // 通过指针输入数组元素
}
// 逆序输出数组元素
printf("The reversed array is: ");
for (int i = n - 1; i >= 0; i--) {
printf("%d ", *(p + i)); // 通过指针输出数组元素
}
return 0;
}
```
首先通过 `scanf` 函数获取输入的整数个数 `n`,然后定义一个数组 `arr` 和一个指向数组首元素的指针变量 `p`,并使用 `scanf` 函数通过指针输入数组元素。接着通过指针变量 `p` 和偏移量 `i` 访问数组元素并逆序输出。其中 `*(p + i)` 可以简写为 `p[i]`。
1、输入n(不大于20)个单精度数存入一维数组,用指针变量处理数组元素的方式将其逆序存放后输出。n从键盘输入。 1、输入n(不大于20)个单精度数存入一维数组,用指针变量处理数组元素的方式将其逆序存放后输出.N从键
以下是使用指针变量处理数组元素的方式将一维数组逆序存放后输出代码,其中n为从键盘输入的整数,a为存放单精度数的一维数组:
```c
#include <stdio.h>
#define N 20
int main() {
float a[N], t, *p = a;
int i, n;
scanf("%d", &n);
for (i = 0; i < n; i++) {
scanf("%f", &a[i]);
}
for (i = 0; i < n / 2; i++) {
t = *(p + i);
*(p + i) = *(p + n - 1 - i);
*(p + n - 1 - i) = t;
}
for (i = 0; i < n; i++) {
printf("%f\n", a[i]);
}
return 0;
}
```
阅读全文
相关推荐












