以下是一个可行的实现:
- #include <stdio.h>
- #include <stdlib.h>
- int *getarray(int n) {
- int *arr = malloc(n * sizeof(int));
-
- for (int i = 0; i < n; i++) {
- arr[i] = i + 1;
- }
-
- return arr;
- }
- int main() {
- int *a = NULL, n, i;
- scanf("%d", &n);
-
- if (n <= 0) {
- printf("请输入一个大于0的整数\n");
- return 0;
- }
-
- a = getarray(n);
-
- for (i = 0; i < n; i++) {
- printf("%d ", a[i]);
- }
-
- free(a);
-
- return 0;
- }
复制代码
首先,我们定义了一个`getarray`函数,它接受一个整数`n`作为参数,并返回一个整型指针。
在`getarray`函数中,我们使用`malloc`函数分配了一个长度为`n`的动态数组。然后,我们使用一个循环将1到n的整数存储在数组中。最后,我们返回数组的首地址。
在`main`函数中,我们首先声明了一个整型指针`a`,并将其初始化为`NULL`。然后,我们通过`scanf`函数从标准输入中读取一个整数`n`。如果输入的n小于或等于0,则输出一条错误消息并结束程序。否则,我们调用`getarray`函数来获得一个长度为n的数组,并将其赋值给指针`a`。
接下来,我们使用一个循环打印数组的元素。最后,我们使用`free`函数释放动态数组的内存。
以上回复来自 -- ChatGPT(FishC官方接口),如未能正确解答您的问题,请继续追问。