zoukankan      html  css  js  c++  java
  • 队列

    队列:
    (3) 循环队列的类型定义

    1   #define Queur Size 100   //应根据具体情况定义该值
    2      typedef char Queue DataType;  //DataType的类型依赖于具体的应用
    3      typedef Sturet{               //头指针,队非空时指向队头元素
    4            int front;              //尾指针,队非空时指向队尾元素的下一位置
    5            int rear;               //计数器,记录队中元素总数
    6            DataType data[QueueSize]
    7      }CirQueue;

    判别队列是"空"还是"满"。解决办法:使用一个计数器记录队列中元素的总数(即队列长度)
    (4) 循环队列的基本运算
      用第三种方法,循环队列的六种基本运算:
      ① 置队空

     void InitQueue(CirQueue *Q)
          {
                  Q->front=Q->rear=0;
                  Q->count=0;     //计数器置0
           }

    ② 判队空

    int QueueEmpty(CirQueue *Q)
           {
                return Q->count==0;  //队列无元素为空
            }

    ③ 判队满

    int QueueFull(CirQueue *Q)
            {
                return Q->count==QueueSize;  //队中元素个数等于QueueSize时队满
             }

    ④ 入队

    void EnQueue(CirQueuq *Q,DataType x)
             {
                if(QueueFull((Q))                   
                       Error("Queue overflow");     //队满上溢
                Q->count ++;                        //队列元素个数加1
                Q->data[Q->rear]=x;                 //新元素插入队尾
                Q->rear=(Q->rear+1)%QueueSize;      //循环意义下将尾指针加1

    ⑤ 出队

    DataType DeQueue(CirQueue *Q)
              {
                  DataType temp;
                  if(QueueEmpty((Q))
                       Error("Queue underflow");     //队空下溢
                  temp=Q->data[Q->front];
                  Q->count--;                        //队列元素个数减1
                  Q->front=(Q->front+1)&QueueSize;   //循环意义下的头指针加1
                  return temp; 
               }

    ⑥取队头元素

    DataType QueueFront(CirQueue *Q)
                {
                    if(QueueEmpty(Q))
                        Error("Queue if empty.");
                    return Q->data[Q->front];
                }

    队列的应用--舞伴问题

    1、问题叙述      假设在周末舞会上,男士们和女士们进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。若两队初始人数不相同,则较长的那一队中未配对者等待下一轮舞曲。现要求写一算法模拟上述舞伴配对问题。

    2、问题分析      先入队的男士或女士亦先出队配成舞伴。因此该问题具体有典型的先进先出特性,可用队列作为算法的数据结构。      在算法中,假设男士和女士的记录存放在一个数组中作为输入,然后依次扫描该数组的各元素,并根据性别来决定是进入男队还是女队。当这两个队列构造完成之后,依次将两队当前的队头元素出队来配成舞伴,直至某队列变空为止。此时,若某队仍有等待配对者,算法输出此队列中等待者的人数及排在队头的等待者的名字,他(或她)将是下一轮舞曲开始时第一个可获得舞伴的人。

    3、具体算法及相关的类型定义

      typedef struct{
               char name[20];
               char sex;  //性别,'F'表示女性,'M'表示男性
           }Person;
           typedef Person DataType;  //将队列中元素的数据类型改为Person
            
           void DancePartner(Person dancer[],int num)
           {//结构数组dancer中存放跳舞的男女,num是跳舞的人数。
                int i;
                Person p;
                CirQueue Mdancers,Fdancers;
                InitQueue(&Mdancers);//男士队列初始化
                InitQueue(&Fdancers);//女士队列初始化
                for(i=0;i<num;i++){//依次将跳舞者依其性别入队
                     p=dancer[i];       
                     if(p.sex=='F')
                         EnQueue(&Fdancers.p);   //排入女队
                     else
                         EnQueue(&Mdancers.p);   //排入男队
                 }
                 printf("The dancing partners are: 
     
    ");
                 while(!QueueEmpty(&Fdancers)&&!QueueEmpty(&Mdancers)){
                       //依次输入男女舞伴名
                       p=DeQueue(&Fdancers);     //女士出队
                       printf("%s        ",p.name);//打印出队女士名
                       p=DeQueue(&Mdancers);     //男士出队
                       printf("%s
    ",p.name);    //打印出队男士名
                 }
                 if(!QueueEmpty(&Fdancers)){ //输出女士剩余人数及队头女士的名字
                       printf("
     There are %d women waitin for the next  round.
    ",Fdancers.count);
                       p=QueueFront(&Fdancers);  //取队头
                       printf("%s will be the first to get a partner. 
    ",p.name);
                  }else
                      if(!QueueEmpty(&Mdancers)){//输出男队剩余人数及队头者名字
                             printf("
     There are%d men waiting for the next   round.
    ",Mdacers.count);
                             p=QueueFront(&Mdancers);
                             printf("%s will be the first to get a partner.
    ",p.name);
                       }
            }//DancerPartners   
  • 相关阅读:
    微信红包开发
    第一次开博客,留此纪念
    数据结构--树(遍历,红黑,B树)
    c++之vector
    动态规划求解最长公共子序列问题
    c++之map
    k-折交叉验证(k-fold crossValidation)
    prim算法
    快速排序算法
    浙大机试题目
  • 原文地址:https://www.cnblogs.com/cancangood/p/3360067.html
Copyright © 2011-2022 走看看