边学边用,忍不住写了个代码,写代码还是挺有意思的,哈哈
//通过动态分配内存打印杨辉三角
#include<iostream>
using namespace std;
int main()
{
int *p=NULL,*q=new int[2], row = 1, i;
*q = *(q+1) = 1;
//在循环外打印前两行
cout<<1<<endl;
row ++;
cout<< *q <<" " << *(q+1) <<endl;
row ++;
//从第三行开始进入循环内进行打印
while(row <= 10)
{
//p指针用来打印当前行的数据
p = new int[row];
//每行的第一个数总是1
*p = 1;
cout<< *p <<" ";
//q指针保存的是上一行的数据
for(i=1;i<=row-2;i++)
{
//通过q这个数组指针计算当前位置的数
*(p+i) = *(q+i-1) + *(q+i);
cout << *(p+i)<<" ";
}
//每行的最后一个数总是1
*(p+row-1) = 1;
//一行打印结束
cout<< *(p+row-1)<<endl;
//删除q所占用的内存空间,重新申请内存,保存当前行的数据
delete []q;
q = new int[row];
for(i=0;i<row;i++)
*(q+i) = *(p+i);
//进入到下一行
row ++;
delete []p;
}
delete []q;
return 0;
}
最后说一句给初学者的经验,先在纸上把主要代码写出来,再输入到电脑上进行编译测试,在纸上会看的明了,思路更明确,改也比较容易,从大学到研究生一直都是这样做的,哪怕是用几页纸的程序。这个程序应该还有优化的空间,因为频繁的申请、释放内存并不好,懒得想了。