|
发表于 2011-8-20 03:30:00
|
显示全部楼层
确定是动态了 在百度上找到了答案 dev C++ 新版本已经支持了 我用的也是dev C++ 5
运行正常 探索精神可加 我还没有试过
较早的编译器是不允许这样做的,所以一些书籍比如以Tc讲解的书本都说数组的下标不能是变量。在vc6.0下亦是如此。
不过在一些较新的编译器如dev c++已经支持了,如下代码不会报错
#include <stdio.h>
#include <stdlib.h>
int main()
{
int a; int i;
scanf("%d",&a);
int c[a];
for( i =0 ;i<a;i++)
scanf("%d",&c);
for( i =0 ;i<a;i++)
printf("%d",c);
}
[i][i]
这个和编译器有关,应该是设计到一些标准规范为题吧,最好还是不要这样写~使用动态分配内存是比较把握和通用的
一维:
cin>>n;
int* a=new int[n];
但是new出来的一定不要忘了delete掉
delete []a; // 正确的用法
delete a; // 错误的用法
后者相当于delete a[0],漏掉了另外n-1个对象。
二维:
设有m行n列
cin>>m>>n;
int **a = new int* [m];
for(int i = 0; i < m; i++)
a[i] = new int [n];
PS:就相当于产生了一个二维数组a[m][n]了,但是对于我们平时声明的数组a[m][n],a[i][j]=a[i*n+j],因为是连续的一片内存,而这样动态声明的数组任意的a[k]都是一个int*类型,即一个地址了,所以只能a[i][j]或者*(*(a+i)+j)来访问数组的元素,而不能a[i*n+j]这样转换着用了
释放内存:
for(int i = 0; i < m; ++i)
delete []a[i];
delete []a;
PS:其实对于c++,我们完全可以充分利用它自己强大而方便的容器,比如vector,之所以动态声明数组,相比是大小不确定,声明太大了怕浪费空间,而vector就不用指定大小,当存的数据变多,自动扩大容量,比如假设vector默认大小是8,当你再往里存第9个元素时,容器自动扩容,变为16,16再不够用,扩为32,2倍2倍的增长,这样就根据需要扩容,不会浪费空间,也可以像普通数组那样直接指定vector的大小,总之普通数组可以的它都可以,普通数组没有的它更有;
一维:
vector<int> a;
a.push_back(k);
k为待存入数组的数,用法一样,可以a[i]这样直接取数,还有各种自带的方法,使用方便极了
vector<int> a;
vector<int> a(5); //指定数组大小是5
vector<int> a(5,3); //数组大小为5,并初始化数组所有元素值为3
二维:
cin>>m>>n;//m行n列
vector<vector<int> > a(m, vector<int>(n)); //这行注意两个> >中间要加空格,否则会被认为是重载>>运算符
for (i = 0; i < m; i++)
for (j = 0; j < n; j++)
a[i][j] = i*j;
for (i = 0; i < m; i++)
for (j = 0; j < n; j++)
cout<<a[j]<<' ';
cout<<endl;[/i][/i][/i][/i][/i][/i][/i][/i] |
|