【转】C语言中动态分配数组
2015-11-15 20:13
381 查看
原文地址:http://blog.chinaunix.net/uid-11085590-id-2914577.html
如何动态的定义及使用数组呢?记得一般用数组的时候都是先指定大小的。当时问老师,老师说是不可以的。后来又问了一位教C++的老师,他告诉我在C++里用new可以做到,一直不用C++,所以也不明白。今天在逛论坛时终于找到了C语言中的用法(看原贴):
int *a;
int N;
scanf("%d", &N);
a = (int *) malloc(N * sizeof(int));
....
free(a);
这样就动态分配了数组a
。数组的长度N可输入确定,也可用程序中的变量确定。但要注意程序结束后要用free()将其释放,否则内存会泄漏。
int main()
{
int i = 0;
int *a;
int N;
printf("Input array length: ");
scanf("%d", &N);
printf("\n");
a = (int *) malloc(N * sizeof(int));//int 可以用*a来代替
for(i = 0; i < N; i++)
{
a[i] = i + 1;
printf("%-5d", a[i]);
if ((i + 1) % 10 == 0)
printf("\n");
}
free(a);
printf("\n");
return 0;
}
这样就完成了数组a
的动态分配,那么多维怎么分配呢?一个道理啊!!!!!!!!!!!!
二维
int main()
{
int nrows,ncolumns;
scanf("%d,%d",nrows,ncolumns);
区别的地方
//为数组分配行数 注意指针多了个*
int **array = malloc(nrows * sizeof(*array));//注意分配的是整形指针的数量 每行元素是个整形指针
/*这里可以写成
int **array;
array=(int**)malloc(nrows*sizeof(int*));//这里int可以写成**array
*/
//对每行分配数组个数(就是二维数组的列数)
for(i = 0; i < nrows; i++)
{
/*
这里int*可以写成*array 其实array是一个指向指针的指针变量,所以要将分配的内存转化为指针类型,在一台计算机中所有的指针变量分配的内存大小相同都是计算机的位数(就是地址线的条数,指针变量存放的是地址与地址线对应可以寻址)
*/
array[i] = (int*)malloc(ncolumns * sizeof(int));
for(l=0;l<ncolumns;l++)< p="">
{
array[i][l]=...
}
}
//付初值以及处理过程
free(array);
return 0;
}
多维一个道理 每增加一维 输入数据就要多一个 定义指针的时候就多一个* 且分配的时候也要多个* 还要多个for循环
三维
int main()
{
int rows,colnums,num;
scanf("%d %d %d",rows,colnums,num);
int ***p=malloc(rows*sizeof(*p));
/*
这里可以写成
int ***p;
p=(int***)malloc(rows*sizeof(int**));//int**可以写成*p
*/
for(int i=0;i<colnums;i++)< p="">
{
p[i]=(int**)malloc(colnums*sizeof(int*));//**p
for(int j=0;j<num;j++)< p="">
{
p[i][j]=(int*)malloc(num*sizeof(int));//这里可以写成*p
for(r=0;r<num;r++)< p="">
{
p[i][j][r]=...
}
}
}
free(p);
return 0;
}
以上扩展内容纯熟个人总结(水平不高) 如果有哪里不对希望高手帮忙指出,谢谢.(暂时代码里面可能还有很多问题,我会慢慢修改)
现在代码应该没有什么问题了 如果还有什么问题请高手指出
如何动态的定义及使用数组呢?记得一般用数组的时候都是先指定大小的。当时问老师,老师说是不可以的。后来又问了一位教C++的老师,他告诉我在C++里用new可以做到,一直不用C++,所以也不明白。今天在逛论坛时终于找到了C语言中的用法(看原贴):
int *a;
int N;
scanf("%d", &N);
a = (int *) malloc(N * sizeof(int));
....
free(a);
这样就动态分配了数组a
。数组的长度N可输入确定,也可用程序中的变量确定。但要注意程序结束后要用free()将其释放,否则内存会泄漏。
int main()
{
int i = 0;
int *a;
int N;
printf("Input array length: ");
scanf("%d", &N);
printf("\n");
a = (int *) malloc(N * sizeof(int));//int 可以用*a来代替
for(i = 0; i < N; i++)
{
a[i] = i + 1;
printf("%-5d", a[i]);
if ((i + 1) % 10 == 0)
printf("\n");
}
free(a);
printf("\n");
return 0;
}
这样就完成了数组a
的动态分配,那么多维怎么分配呢?一个道理啊!!!!!!!!!!!!
二维
int main()
{
int nrows,ncolumns;
scanf("%d,%d",nrows,ncolumns);
区别的地方
//为数组分配行数 注意指针多了个*
int **array = malloc(nrows * sizeof(*array));//注意分配的是整形指针的数量 每行元素是个整形指针
/*这里可以写成
int **array;
array=(int**)malloc(nrows*sizeof(int*));//这里int可以写成**array
*/
//对每行分配数组个数(就是二维数组的列数)
for(i = 0; i < nrows; i++)
{
/*
这里int*可以写成*array 其实array是一个指向指针的指针变量,所以要将分配的内存转化为指针类型,在一台计算机中所有的指针变量分配的内存大小相同都是计算机的位数(就是地址线的条数,指针变量存放的是地址与地址线对应可以寻址)
*/
array[i] = (int*)malloc(ncolumns * sizeof(int));
for(l=0;l<ncolumns;l++)< p="">
{
array[i][l]=...
}
}
//付初值以及处理过程
free(array);
return 0;
}
多维一个道理 每增加一维 输入数据就要多一个 定义指针的时候就多一个* 且分配的时候也要多个* 还要多个for循环
三维
int main()
{
int rows,colnums,num;
scanf("%d %d %d",rows,colnums,num);
int ***p=malloc(rows*sizeof(*p));
/*
这里可以写成
int ***p;
p=(int***)malloc(rows*sizeof(int**));//int**可以写成*p
*/
for(int i=0;i<colnums;i++)< p="">
{
p[i]=(int**)malloc(colnums*sizeof(int*));//**p
for(int j=0;j<num;j++)< p="">
{
p[i][j]=(int*)malloc(num*sizeof(int));//这里可以写成*p
for(r=0;r<num;r++)< p="">
{
p[i][j][r]=...
}
}
}
free(p);
return 0;
}
以上扩展内容纯熟个人总结(水平不高) 如果有哪里不对希望高手帮忙指出,谢谢.(暂时代码里面可能还有很多问题,我会慢慢修改)
现在代码应该没有什么问题了 如果还有什么问题请高手指出
相关文章推荐
- c++primer第十章习题(2)
- C++深拷贝
- c++基础知识梳理(2)
- LeetCode Two Sum 及C++map浅显理解
- c++ 11 多线线程系列-----------原子操作(atomic operation)
- IMU中地磁计的椭球面拟合标定法与C++实现
- C语言学习总结(一) 基本语法
- c语言构造简单的线性表
- C语言scanf函数输入时键盘缓冲区\n的问题[经典问题]
- C语言复杂类型声明
- c语言之多级指针理解二
- hdu 2234 无题I (IDA*+dfs)
- hdu 1813(IDA*算法+dfs)
- 【C语言】 实现strcmp
- C++ 静态成员函数使用不需要声明
- C++设计模式[十三]命令模式
- [C++] Vtable(虚函数表)
- 用C++11学习多线程
- C++学习第三课—数组
- C++设计模式[十二]职责链模式