C++学习实战——通过动态分配内存打印杨辉三角

边学边用,忍不住写了个代码,写代码还是挺有意思的,哈哈

//通过动态分配内存打印杨辉三角
#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;
}

  最后说一句给初学者的经验,先在纸上把主要代码写出来,再输入到电脑上进行编译测试,在纸上会看的明了,思路更明确,改也比较容易,从大学到研究生一直都是这样做的,哪怕是用几页纸的程序。这个程序应该还有优化的空间,因为频繁的申请、释放内存并不好,懒得想了。

猜你喜欢

转载自blog.csdn.net/xinwenfei/article/details/68489547
今日推荐