下面是代码#include<iostream>
using namespace std;
int main()
{
int **a;
int n,i;
cin>>n;
using namespace std;
int main()
{
int **a;
int n,i;
cin>>n;
a=new int* [2];//申请两行的二维数组
for(i=0;i<2;i++)
a[i]=new int[n];//两行n列运行时输入
for(i=0;i!=n;i++)
delete[] a[i];//对申请的动态空间进行删除
delete[] a;
return 0;
}
//运行的时候老是终止,应该没错吧?!为什么呢?!
本人用的是这个编译器
谢谢大家!
解决方案
4
二维数据就是一维数组,没有本质区别的,所以使用:
int *p=new int[col*row]就行了。
int *p=new int[col*row]就行了。
10
输入别的当然不行啊,你new的空间才能delete
9
仅供参考:
#include <stdio.h> #include <stdlib.h> int **newarr2d(int rows,int cols) { int **p,i; p=new int *[rows]; if (NULL==p) exit(1); for (i=0;i<rows;i++) { p[i]=new int[cols]; if (NULL==p[i]) exit(1); } return p; } void deletearr2d(int **p,int rows) { int i; for (i=0;i<rows;i++) { delete[] p[i]; } delete[] p; } int main() { int **arr2d,i,j,r,c; r=4; c=5; //在堆中开辟一个4×5的二维int数组 arr2d=newarr2d(r,c); for (i=0;i<r;i++) { for (j=0;j<c;j++) { arr2d[i][j]=i*c+j; } } for (i=0;i<r;i++) { for (j=0;j<c;j++) { printf(" %2d",arr2d[i][j]); } printf("\n"); } deletearr2d(arr2d,r); r=6; c=3; //在堆中开辟一个6×3的二维int数组 arr2d=newarr2d(r,c); for (i=0;i<r;i++) { for (j=0;j<c;j++) { arr2d[i][j]=i*c+j; } } for (i=0;i<r;i++) { for (j=0;j<c;j++) { printf(" %2d",arr2d[i][j]); } printf("\n"); } deletearr2d(arr2d,r); return 0; } // 0 1 2 3 4 // 5 6 7 8 9 // 10 11 12 13 14 // 15 16 17 18 19 // 0 1 2 // 3 4 5 // 6 7 8 // 9 10 11 // 12 13 14 // 15 16 17 //
14
a=new int* [2];
for(i=0;i<2;i++)
上面两句中的2也改成n,然后你就可以n想多少就多少了
否则申请的是2,释放的时候不是可能导致出错
for(i=0;i<2;i++)
上面两句中的2也改成n,然后你就可以n想多少就多少了
否则申请的是2,释放的时候不是可能导致出错
5
崩溃的时候在弹出的对话框按相应按钮进入调试,按Alt+7键查看Call Stack即“调用堆栈”里面从上到下列出的对应从里层到外层的函数调用历史。双击某一行可将光标定位到此次调用的源代码或汇编指令处,看不懂时双击下一行,直到能看懂为止。
其实电脑开机后物理内存的每个字节都是可读写的,从来不会原因是所谓的new、delete或malloc、free而被创建、销毁。区别仅在于操作系统内存管理模块在你读写时能否能发现并能否采取相应动作而已。操作系统管理内存的粒度不是字节而是页,一页通常为4KB。
其实电脑开机后物理内存的每个字节都是可读写的,从来不会原因是所谓的new、delete或malloc、free而被创建、销毁。区别仅在于操作系统内存管理模块在你读写时能否能发现并能否采取相应动作而已。操作系统管理内存的粒度不是字节而是页,一页通常为4KB。