C语言中动态分配数组
2015-09-18 16:27
483 查看
如何动态的定义及使用数组呢?记得一般用数组的时候都是先指定大小的。当时问老师,老师说是不可以的。后来又问了一位教C++的老师,他告诉我在C++里用new可以做到,一直不用C++,所以也不明白。今天在逛论坛时终于找到了C语言中的用法(看原贴):
int *a;
int N;
scanf("%d", &N);
a = (int *) malloc(N * sizeof(int));
....
free(a);
这样就动态分配了数组a
。数组的长度N可输入确定,也可用程序中的变量确定。但要注意程序结束后要用free()将其释放,否则内存会泄漏。
#include
#include
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
的动态分配,那么多维怎么分配呢?一个道理啊!!!!!!!!!!!!
二维
#include
#include
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循环
三维
#include
#include
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;
}
以上扩展内容纯熟个人总结(水平不高) 如果有哪里不对希望高手帮忙指出,谢谢.(暂时代码里面可能还有很多问题,我会慢慢修改)
现在代码应该没有什么问题了 如果还有什么问题请高手指出
感谢:http://blog.chinaunix.net/uid-11085590-id-2914577.html
int *a;
int N;
scanf("%d", &N);
a = (int *) malloc(N * sizeof(int));
....
free(a);
这样就动态分配了数组a
。数组的长度N可输入确定,也可用程序中的变量确定。但要注意程序结束后要用free()将其释放,否则内存会泄漏。
#include
#include
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
的动态分配,那么多维怎么分配呢?一个道理啊!!!!!!!!!!!!
二维
#include
#include
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循环
三维
#include
#include
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;
}
以上扩展内容纯熟个人总结(水平不高) 如果有哪里不对希望高手帮忙指出,谢谢.(暂时代码里面可能还有很多问题,我会慢慢修改)
现在代码应该没有什么问题了 如果还有什么问题请高手指出
感谢:http://blog.chinaunix.net/uid-11085590-id-2914577.html
相关文章推荐
- C++中传递数组参数的几种用法和注意点
- swig C#链接c++ dll
- Effective C++——条款45(第7章)
- c++ 抽象概念,内存格局,浅拷贝,深拷贝,临时对象,无名对象
- C++中不能被定义为虚函数的函数
- 详解C++编程中的单目运算符重载与双目运算符重载
- c/c++复习日记 1.不带缓存的I/O和标准I/O
- C++运算符重载规则详解
- 矩阵乘法算法
- 简介C++编程中的运算符重载
- C++ Primer Plus 第6版 中文版 第7章编程练习
- C++读入输出优化
- 【C++】vector、list、map、set
- C++:类和对象
- c语言 词法分析
- c/c++ 中结构体的初始化与类的初始化的不同之处
- C++ typeid() 基类必须是多态类
- Java和C++程序在编译和运行上有什么区别
- c++ 读取stdin 获取标准输出内容
- c++ 常用数据接口 set