数据结构--队列及其及其应用(打印杨辉三角,魔王语言)

本文介绍了如何使用数据结构中的队列来实现打印杨辉三角,并探讨了利用队列解析魔王语言的过程,通过示例代码展示了具体实现。
摘要由CSDN通过智能技术生成

打印杨辉三角:
在这里插入图片描述

代码:

#include<cstdio>
#include<cstdlib>

#define MaxSize 200

typedef int QElemType;
typedef struct {
   
    QElemType *base;    //指向动态分配的数组中的元素
    int front;  //记录队列头
    int rear;   //记录队列尾
}SqQueue;

void InitQueue(SqQueue *Q){
   
    //构造一个空队列Q
    Q->base = (QElemType *)malloc(sizeof(QElemType)*MaxSize); //申请一段长度为MaxSize*sizeof(int)的连续空间,用Q->base存放
    if(!Q->base) exit(1);   //验证,Q不为空,返回1
    Q->front = Q->rear = 0;
}

int QueueLength(SqQueue *Q){
   
    //返回Q的元素个数,即队列的长度
    int e;
    e= (Q->rear - Q->front + MaxSize) % MaxSize;
    return e;
}

void EnQueue(SqQueue *Q, QElemType e){
   
    //插入的元素e为Q的新的队尾元素
    if((Q->rear+1) % MaxSize == Q->front) exit(1);

    Q->base[Q->rear] = e;
    Q->rear = (Q->rear + 1) % MaxSize;
}

void DeQueue(SqQueue *Q){
   
    //若队列不空,则删除Q的队头元素,可以用e返回其值
    if(Q->front == Q->rear)
        exit(1);    //返回1,exit为C++的退出函数,声明于stdlib.h中,对于C++其标准的头文件为cstdlib
    //e=Q.base[Q.front];
    Q->front = (Q->front+1) % MaxSize;
}

int GetHead(SqQueue *Q){
   
    //返回队头元素
    return Q->base[Q->front];
}

int main(){
   
    int N,n,c;
    QElemType t,x;
    SqQueue f,*Q;   //用Q接收f的地址
    Q=&f;

    InitQueue(Q);   //初始化,构造一个空队列

    printf("请输入杨辉三角规模:\n");
    scanf("%d",&N
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值