我也很想学C++,不过我想先学C
[[it] 本帖最后由 酷猫 于 2008-4-17 23:59 编辑 [/it]]
----------------解决方案--------------------------------------------------------
你可以定义一个指向指针的指针
用这个指针动态申请一个长度为N的指针数组
再用这N个指针根据不同情况申请N个不同长度的一维数组
这就完成了N个不定长的二维数组,而且N也是动态得到的
[[it] 本帖最后由 moonwalker 于 2008-4-18 00:13 编辑 [/it]]
----------------解决方案--------------------------------------------------------
[bo]以下是引用 [un]酷猫[/un] 在 2008-4-17 23:55 的发言:[/bo]
TO 6楼:
谢谢!我是不想把数组的维数限制住,想根据N和M的输入值来确定数组的大小。
( 这个想发源与飞燕的论坛上的一道题---N阶和幻方,因为N值不确定,所以就想到了动态分配) ...
TO 6楼:
谢谢!我是不想把数组的维数限制住,想根据N和M的输入值来确定数组的大小。
( 这个想发源与飞燕的论坛上的一道题---N阶和幻方,因为N值不确定,所以就想到了动态分配) ...
如果仅仅是做这个题,你直接开一维就可以了
一维直接当二维使用,这样很方便,不过写起来不太优雅
----------------解决方案--------------------------------------------------------
TO 13楼
想过用一维,可是在超出幻方边界的时候,思维就跟不上了,所以还是想用二维
(不仅仅是为这道题,对与刚学C的我来说,能学到一个新的知识跟重要)
----------------解决方案--------------------------------------------------------
回8#:重载[]的话,就固定了低维的数目了……除非你重载(),但是这样不好看……
回14#:多维也是映射到一维的,直接使用一维数组,反而能更好地领悟高维数组的思想。一般如果我遇到这种动态大小的题,都是开一个一维数组,然后直接手工计算映射(或者像飞燕说的那样,用一个函数――操作符重载来完成),这样灵活,而且省空间。
----------------解决方案--------------------------------------------------------
你所说的低维数目是什么?
----------------解决方案--------------------------------------------------------
TO 13 楼 谢谢!
TO 15 楼 谢谢!
正在尝试用一维,努力中......
感谢!!!
----------------解决方案--------------------------------------------------------
TO16:低维就是相对靠后的维的大小……
比如a[2][4][5],4和5都固定……只有2是可以写成(*a)从而不固定的……
----------------解决方案--------------------------------------------------------
[bo]以下是引用 [un]StarWing83[/un] 在 2008-4-19 11:08 的发言:[/bo]
TO16:低维就是相对靠后的维的大小……
比如a[2][4][5],4和5都固定……只有2是可以写成(*a)从而不固定的……
TO16:低维就是相对靠后的维的大小……
比如a[2][4][5],4和5都固定……只有2是可以写成(*a)从而不固定的……
那你错了,低维不但不固定,并且可以在运行期间随时伸缩,你喜欢设置多少就多少
----------------解决方案--------------------------------------------------------
/************************
19-04-08 14:00
DEV-C++
************************/
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
int a; // [a][b]
int b; // [a][b]
printf("请输入二维int数组的维数a和b: ");
scanf("%d %d", &a, &b);
while(getchar() != '\n');
int (* p)[b]; // 指向一个不定长的数组的(int)数组
p = malloc(sizeof(int) * a * b);
int i, j;
for(i = 0; i < a; i++)
for(j = 0; j < b; j++)
scanf("%d", &p[i][j]);
for(i = 0; i < a; i++)
{
for(j = 0; j < b; j++)
printf("%d ", p[i][j]);
putchar('\n');
}
system("Pause");
return 0;
}
[[it] 本帖最后由 cosdos 于 2008-4-19 14:03 编辑 [/it]]
----------------解决方案--------------------------------------------------------