我正试图制作一个' int ** arr [5]'其中的每个单元格都包含一个< int *数组&#39 ;,每个< int * *数组'有不同的大小。每当我试图打印其中一个单元格时,它只打印其中的第一个数字,为什么会发生?我该如何打印整个阵列?
#include <stdio.h>
#include <stdlib.h>
void sortNumber(int** arr[]);
int main(void)
{
int i = 0;
int* arr1[3] = { 2, 5, 8 };
int* arr2[2] = { 1, 7 };
int* arr3[6] = { 5, 1, 8, 3, 7 ,12 };
int* arr4[4] = { 3, 9, 4, 29};
int* arr5[5] = { 4, 11, 17, 23, 25 };
int** bigArr[5] = {*arr1, *arr2, *arr3, *arr4, *arr5};
sortNumber(bigArr);
system("PAUSE");
return 0;
}
void sortNumber(int** arr[])
{
printf("%d", arr[1]);
}
答案 0 :(得分:0)
这里有几个问题。我并不完全清楚你的目标是什么,但看起来你想要处理第二维有不同长度条目的二维数组。
int* arr1[3] = { 2, 5, 8 };
在那里你创建一个包含指针的数组。您正在使用数字初始化元素,但这些是指针 - 条目指向由数字表示的内存地址。即第一个元素指向内存地址2 - 是真的有意吗?如果你想存储数字,你需要在这里使用一个简单的数组。
int** bigArr[5] = {*arr1, *arr2, *arr3, *arr4, *arr5};
在此,您将arr1
等的值分配给bigArr
的元素。但是,由于您取消引用arr1
,因此您无法获得指向数组的指针。而是获得第一个元素的值(*arr1
与arr1[0]
基本相同)。所以现在bigArr
存储int**
个值,它们只是子数组的第一个元素。没有存储指向子数组的指针。你可以通过指针或数组访问来访问数组元素,这基本上是出了什么问题。
一般说来指针:以下两行表现相同:
int a = arr1[1];
int b = *(arr1 + 1);
以及您可以通过两种不同的方式获取指向数组的指针。最后,两个指针都指向数组的第一个元素:
int array[] = {1, 2, 3};
int *ptr1 = array;
int *ptr2 = &array[0];
最后,C不存储数组的长度 - 您需要知道这一点。
我假设您要存储这样的数据结构:
[
[ 2, 5, 8 ],
[ 1, 7 ],
[ 5, 1, 8, 3, 7, 12 ],
[ 3, 9, 4, 29 ],
[ 4, 11, 17, 23, 25 ]
]
要做到这一点,你不需要双指针。此外,您需要存储子阵列的长度。解决这个问题的方法可能是使用struct数组。
struct row {
int* data;
int length;
};
int arr1[3] = { 2, 5, 8 };
int arr2[2] = { 1, 7 };
// ...
struct row r1 = {arr1, 3};
struct row r2 = {arr2, 2};
// ...
struct row *bigArr[] = {r1, r2, ...};
现在sortNumber
更改为
void sortNumber(struct row* r)
{
for(int i = 0; i < r->length; i++) {
printf("%i ", r->data[i]);
}
printf("\n");
}