java 杨辉三角 循环队列_循环队列打印杨辉三角

#include

using namespace std;

const int maxlen=256;

enum error_code{

success=0,

overflow=1,

underflow=2,

rangeerror=3

};

class queue{

public:

queue();

bool      empty()const;

bool      full() const;

error_code     get_front(int &x)const;//取队头元素

error_code     append(const int x);//入队

error_code     serve();//出队

private:

int         count;

int         data[maxlen];

int front,rear;

};

queue::queue()

{

count = 0;

front = rear = 0;

}

bool    queue::empty( )const

{

if ( count == 0 )    return true;

return         false;   //等价于:return front == rear;

}

bool   queue::full( )const

{

if ( count == maxlen - 1 )    return true;

return   false;   //等价于:return ( rear + 1 ) % maxlen == front ;

}

error_code    queue::get_front(int &x)const

{

if ( empty() )      return underflow;

x = data[ (front + 1 ) % maxlen ];

return success;

}

error_code   queue::append(const int x)

{

if ( full() )    return overflow;

rear = ( rear + 1 ) % maxlen ;

data[rear] = x;

count ++;

return   success;

}

error_code   queue::serve()

{

if ( empty() )    return underflow;

front = ( front + 1 ) % maxlen;

count --;

return  success;

}

int main()         // 利用队列Q打印n行杨辉三角形

{

int n,i,j,s1,s2;  queue Q;                 // 用queue代表某种队列类型

error_code Ec;                        // 定义错误类型代码,以便调用函数时用

cout<

cin>>n;

cout<<1<

Ec=Q.append(1);                     // 所输出的1入队

for(i=2; i<=n; i++)                 // 依次计算并输出第2~i行上的数据

{  s1=0;                                   // 存放前一个出队的数

for(j=1; j<=i-1; j++)          //计算并输出第i行上前 i-1 个数据

{   Ec= Q.get_front(s2);  Ec=Q.serve( );     // 取队头元素

cout<

Ec=Q.append(s1+s2);      // 所输出的当前行中的元素入队

s1=s2;                                // 调整变量的值

}

cout<<1<

Ec=Q.append(1);                  //本行最后的1入队

}

return 0;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值