zoukankan      html  css  js  c++  java
  • 数据结构-链队

      1 #include <iostream>
      2 #include <stdlib.h>
      3 
      4 using namespace std;
      5 
      6 typedef struct QNode
      7 {
      8     int data;
      9     struct QNode *next;
     10 }QNode; //队结点
     11 typedef struct
     12 {
     13     QNode *front;
     14     QNode *rear;
     15 }LiQueue;//链队类型
     16 
     17 void InitQueue(LiQueue *&Q)
     18 {
     19     Q=(LiQueue*)malloc(sizeof(LiQueue));
     20     Q->front=Q->rear=NULL;
     21 }
     22 
     23 int IsEmpty(LiQueue *Q)
     24 {
     25     if(Q->front==NULL||Q->rear==NULL)
     26         return 1;
     27     else
     28         return 0;
     29 }
     30 
     31 void EnQueue(LiQueue *Q,int e)
     32 {
     33     QNode *p;
     34     p=(QNode*)malloc(sizeof(QNode));
     35     p->data=e;
     36     p->next=NULL;
     37 
     38     if(Q->rear==NULL)
     39         Q->front=Q->rear=p;
     40     else
     41     {
     42         Q->rear->next=p;
     43         Q->rear=p;
     44     }
     45 }
     46 
     47 int DeQueue(LiQueue *Q,int &e)
     48 {
     49     QNode *p;
     50     if(Q->rear==NULL)
     51         return 0;
     52     else
     53         p=Q->front;
     54 
     55     if(Q->front==Q->rear)
     56         Q->front=Q->rear=NULL;
     57     else
     58         Q->front=Q->front->next;
     59     e=p->data;
     60     free(p);
     61     return 1;
     62 }
     63 
     64 int Print(LiQueue *Q)
     65 {
     66     if(Q->front==NULL||Q->rear==NULL)
     67     {
     68         cout<<"
    队空!
    ";
     69         return 0;
     70     }
     71 
     72     QNode *p;
     73     p=Q->front;
     74     cout<<"队中元素依次为:
    ";
     75     while(p!=Q->rear)
     76     {
     77         cout<<"  "<<p->data<<"  ";
     78         p=p->next;
     79     }
     80     cout<<"  "<<p->data<<"  ";
     81     return 1;
     82 }
     83 
     84 int main()
     85 {
     86     int i,e;
     87     LiQueue *Q;
     88     InitQueue(Q);
     89     for(i=0;i<10;++i)
     90         EnQueue(Q,i);
     91     if(IsEmpty(Q)==1)
     92         cout<<"
    队空!
    ";
     93     else
     94         cout<<"
    队非空!
    ";
     95     Print(Q);
     96     cout<<"
    --------------------------------
    ";
     97     cout<<"依次出队3个元素为:
    ";
     98     for(i=0;i<3;++i)
     99     {
    100         DeQueue(Q,e);
    101         cout<<"  "<<e<<"  ";
    102     }
    103     if(IsEmpty(Q)==1)
    104         cout<<"
    队空!
    ";
    105     else
    106         cout<<"
    队非空!
    ";
    107     Print(Q);
    108     cout<<"
    --------------------------------
    ";
    109 
    110     return 0;
    111 }
  • 相关阅读:
    ado 查询文件数据库
    S60平台简体汉字处理浅谈转symbian wiki
    symbian在收件箱创建短信(转)
    symbian得到收件箱中未读短信的数目
    enable marquee with the animated in the ListBox
    如何为Series60绘制一个常驻顶端的提示图标 [symbian]
    Symbian 得到左右软键项(CBA)的内容
    asp.net 中如何请求一个其它网站的页面
    使S60程序全屏运行,fullscreen
    symbian程序在后台运行
  • 原文地址:https://www.cnblogs.com/Xbert/p/5088163.html
Copyright © 2011-2022 走看看