青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我心飛翔

有事不慌,無事不荒,有容乃大,無欲則剛,以德立綱,外圓內(nèi)方。

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  1 隨筆 :: 9 文章 :: 13 評論 :: 0 Trackbacks

//數(shù)據(jù)結(jié)構(gòu)(C語言版)中棧的習(xí)題

#include<stdlib.h>
#include<stdio.h>
#include<malloc.h>
#include<conio.h>
#define ERROR 0
#define OK 1
typedef struct{
  int OccurTime;
  int NType;
}Event;
typedef struct{
 int ArrivalTime;
 int Duration;
}QElemType;
struct LNODE
{
  Event data;
  struct LNODE *next;
};
typedef struct LNODE LNode;
typedef struct LNODE *LinkList;
typedef struct LNODE *EvenList;
typedef struct QNode{
 QElemType elem;
 struct QNode *next;
}QNode,*QueuePtr;
typedef struct
{ QueuePtr front;
  QueuePtr rear;
}LinkQueue;
EvenList ev;
Event en;
LinkQueue q[5];
QElemType customer;
int TotalTime,CustomerNum,CloseTime;

int InitList(EvenList *L)
{
  *L=(LNode *)malloc(sizeof(LNode));
  if(!(*L))   exit(ERROR);
  (*L)->next=NULL;
  return OK;
}
int DelFirst(EvenList *L,Event *e)
{ LNode *pc,*q;
  pc=*L;q=pc->next;
 pc->next=q->next;*e=q->data;return OK;}
int ListEmpty(LNode L)
{LNode *p;
 int j=0;
 p=L.next;
 while(p)
   {j++;break;}
 if(j==0) return 1;
 else return 0;
}
int compare(Event a,Event b)
{ if(a.OccurTime>b.OccurTime) return 1;
  else if(a.OccurTime==b.OccurTime) return 0;
  else return -1;
}
int OrderInsert(EvenList *L,Event e,int (* cmp)(Event ,Event ))
{ LNode *p,*pc;/*把事件插入鏈表*/
 p=(LNode *)malloc(sizeof(LNode));/*分配空間*/
 if(!p) { printf("not"); return(0);}
 if(ListEmpty(**L))
 { p->data=e;p->next=(*L)->next;(*L)->next=p;}
 else {
   switch(cmp(((*L)->next)->data,e))
  {case -1:pc=(*L)->next;
   while(pc->next!=NULL)
   {
    if((pc->next)->data.OccurTime<=e.OccurTime)
        pc=pc->next;
    else break;
   }
       p->data=e;p->next=pc->next;/*把它接在比它大的前*/
       pc->next=p;break;
     case 0:pc=(*L)->next;/*相等時,接在相等的后面*/
     p->data=e;p->next=pc->next;
     pc->next=p;break;
     case 1:p->data=e;p->next=(*L)->next;
        (*L)->next=p;break;/*小于時,接在最前面*/
 }}
 return 1;
}
void DestroyList(EvenList *L)/*銷毀表*/
{LNode *p;
 while(*L)
   {p=(*L)->next;free(*L);*L=p;}
}
int InitQueue(LinkQueue *Q)/*初始化隊列*/
{ Q->front=Q->rear=(QueuePtr)malloc(sizeof(QNode));
 if(!Q->front) exit(0);
 (Q->front)->next=NULL;
 return OK;
}
int DestroyQueue(LinkQueue *Q)/*銷毀隊列*/
{ while(Q->front)
    { Q->rear=Q->front->next;
     free(Q->front);
     Q->front=Q->rear;
    }
 return OK;
}
int EnQueue(LinkQueue *Q,QElemType e)/*插在隊最后*/
{QueuePtr p;
 p=(QueuePtr)malloc(sizeof(QNode));
 if(!p) exit(0);
 p->elem=e;p->next=NULL;
 (Q->rear)->next=p;
 Q->rear=p;/*重新設(shè)置隊尾*/
 return OK;
}
int QueueEmpty(LinkQueue Q)
{ if(Q.front==Q.rear) return OK;
 else return 0;}
int DelQueue(LinkQueue *Q,QElemType *e)/*刪除隊的第一個元素*/
{QueuePtr p;
 if(QueueEmpty(*Q)) return ERROR;
 p=(Q->front)->next;
 *e=p->elem;
 (Q->front)->next=p->next;
 if(Q->rear==p) Q->rear=Q->front;
 free(p);
 return OK;
}
void GetHead(LinkQueue Q,QElemType *a)
{QNode *p;
 if(Q.front==Q.rear) exit(0);
 p=(Q.front)->next;
 *a=p->elem;
}
int QueueLength(LinkQueue Q)/*隊的長度*/
{ int i=0;
 QNode *pc;
 if(Q.front==Q.rear) return 0;
 pc=Q.front;
 while(pc->next)
 {i++;pc=pc->next;}
 return i;
}
int Mininum(LinkQueue *Q)/*求長度最短的隊*/
{ int a[4],e,j,i;
  for(i=1;i<=4;i++)
      a[i-1]=QueueLength(Q[i]);
  e=a[0];j=1;
  for(i=1;i<=3;i++)
      if(e>a[i]) {e=a[i];j=i+1;}
  return j;
}
void OpenForDay()/*初始化操作*/
{ int i;
  TotalTime=0;CustomerNum=0;/*初始化累計時間和客戶數(shù)*/
  InitList(&ev);
  en.OccurTime=0;en.NType=0;/*設(shè)定第一個客戶到達(dá)事件*/
  OrderInsert(&ev,en,compare);/*把它插入事件表*/
  for(i=1;i<=4;i++) InitQueue(&q[i]);/*置空隊列*/
}
void Random(int *a,int *b)/*生成隨機(jī)數(shù),a為每個客戶辦理時間在30分鐘內(nèi),
                           b 為兩相隔客戶到達(dá)的間隔時間不超過5分鐘*/
{ *a=0+rand()%30;*b=0+rand()%5;}
void CustomerArrived()/*處理客戶到達(dá)事件*/
{int durtime,intertime,t,i,b;
 ++CustomerNum;/*記錄客戶數(shù)*/
 Random(&durtime,&intertime);
 b=en.OccurTime;
 t=en.OccurTime+intertime;/*下一客戶到達(dá)時刻*/
 if(t<CloseTime)
    {en.OccurTime=t;en.NType=0; 
     OrderInsert(&ev,en,compare);
    }
 i=Mininum(q);/*求隊列最短*/
 customer.ArrivalTime=b;customer.Duration=durtime;/*為要插入隊的客戶設(shè)置到達(dá)時間和辦理所需時間*/
 EnQueue(&q[i],customer);
 if(QueueLength(q[i])==1)
     {en.OccurTime=b+durtime;en.NType=i;
      OrderInsert(&ev,en,compare);/*設(shè)定第i 個離開事件并插入事件表*/
      }
}
void CustomerDeparture()/*處理客戶離開事件*/
{int i;
 i=en.NType;DelQueue(&q[i],&customer);/*刪除第i隊列的排頭客戶*/
 TotalTime+=en.OccurTime-customer.ArrivalTime;/*累計客戶逗留時間*/
 if(!QueueEmpty(q[i]))/*設(shè)定第i隊列的一個將要離開事件并插入事件表*/
    { GetHead(q[i],&customer);/*得到它的資料*/
     en.OccurTime+=customer.Duration;en.NType=i;
     OrderInsert(&ev,en,compare);
     }
}
void Bank_Simulation()
{
 OpenForDay();/*初始化*/
 while(!ListEmpty(*ev))/*非空時,刪掉表里的第一個*/
   { DelFirst(&ev,&en);
     if(en.NType==0)
  CustomerArrived();/*是客戶還沒辦理的,就處理到達(dá)事件*/
     else CustomerDeparture();/*否則處理離開事件*/
   }
 printf("The Average Time is %.2f\n",(float)TotalTime/CustomerNum);
}
void main()
{scanf("%d",&CloseTime);/*輸入關(guān)門時間*/
 Bank_Simulation();
 getch();
}

posted on 2005-10-18 23:23 無情雨 閱讀(477) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美激情视频给我| 亚洲午夜电影| 99这里只有精品| 韩国av一区| 国产精品久久久久久户外露出| 久久久久国色av免费看影院| 亚洲欧美中文另类| 亚洲尤物在线视频观看| 一卡二卡3卡四卡高清精品视频| 日韩午夜在线视频| 在线免费观看成人网| 国产一区成人| 狠狠入ady亚洲精品| 欧美国产大片| 免费成人av| 欧美+日本+国产+在线a∨观看| 久久久久网址| 国内精品国产成人| 狠狠色丁香婷综合久久| 久久久久久国产精品mv| 欧美激情一区二区三区不卡| 欧美aaaaaaaa牛牛影院| 亚洲精品一区二区在线| 中日韩美女免费视频网站在线观看| 午夜精品久久久久影视| 久久网站热最新地址| 模特精品在线| 浪潮色综合久久天堂| 亚洲人成7777| 99riav久久精品riav| 亚洲欧美日韩国产成人| 欧美一区二视频| 欧美高清你懂得| 欧美视频一区二区在线观看| 国产伦精品一区二区三区四区免费| 狠狠色狠狠色综合人人| 一本色道久久综合亚洲精品按摩| 亚洲午夜精品网| 久久久久一区二区| 亚洲国产你懂的| 亚洲麻豆国产自偷在线| 久久久91精品国产| 欧美制服丝袜第一页| 另类酷文…触手系列精品集v1小说| 欧美好吊妞视频| 亚洲一区二区免费视频| 久久久蜜臀国产一区二区| 亚洲综合欧美日韩| 麻豆freexxxx性91精品| 国产精品视频男人的天堂| 亚洲国产欧美日韩| 欧美一进一出视频| 亚洲欧美另类久久久精品2019| 正在播放亚洲| 免费亚洲一区二区| 亚洲欧美中文另类| 中文在线不卡视频| 欧美大片一区二区| 亚洲国产精品一区二区第四页av| 国产综合在线看| 亚洲欧美日韩一区二区三区在线观看| 欧美激情久久久久久| 在线日本高清免费不卡| 一区二区三区|亚洲午夜| 久久高清免费观看| 亚洲乱码久久| 麻豆精品网站| 亚洲综合色丁香婷婷六月图片| 亚洲视频网站在线观看| 久久精品av麻豆的观看方式| 亚洲精品少妇| 亚洲一区在线观看免费观看电影高清| 欧美成人综合在线| 亚洲电影免费观看高清完整版在线观看| 亚洲欧美日本国产有色| 亚洲国产欧美一区二区三区久久 | 在线观看亚洲视频| 午夜精品999| 欧美一级播放| 亚洲影院免费观看| 国产精品免费看片| 亚洲欧美文学| 亚洲一区二区三区乱码aⅴ| 欧美色欧美亚洲另类七区| 99热在这里有精品免费| 91久久中文| 欧美三级视频在线播放| 亚洲午夜久久久久久久久电影院 | 欧美日韩一级视频| 国产欧美一区二区三区久久| 亚洲免费伊人电影在线观看av| 亚洲国产一区二区a毛片| 欧美精品久久一区二区| 在线亚洲欧美| 亚洲视频一区| 亚洲精品国产精品国自产观看| 久久在线免费观看| 亚洲精品视频在线观看网站| 亚洲电影有码| 久久久久久久久久久久久女国产乱| 国产亚洲精品久久久久动| 欧美专区在线播放| 中文精品99久久国产香蕉| 欧美福利一区| 亚洲国产成人精品久久| 一区二区三欧美| 欧美精品v国产精品v日韩精品| 一区二区高清视频| 欧美一区二区精品在线| 国产亚洲精品久久飘花| 久久国产精品黑丝| 欧美一区国产在线| 欧美国产精品人人做人人爱| 久久蜜桃香蕉精品一区二区三区| 亚洲国产成人高清精品| 欧美尤物一区| 亚洲欧美日韩另类精品一区二区三区| 欧美风情在线观看| 欧美三区视频| 欧美激情1区2区| 久久一区国产| 欧美与黑人午夜性猛交久久久| 久久久久国产精品人| 欧美国产日韩免费| 免费看黄裸体一级大秀欧美| 亚洲一卡二卡三卡四卡五卡| 国产精品久久一卡二卡| 国产日韩一区| 欧美色播在线播放| 亚洲图片欧洲图片av| 久久精品夜色噜噜亚洲a∨| 亚洲精选大片| 久久看片网站| 久久www成人_看片免费不卡| 香蕉久久精品日日躁夜夜躁| 欧美一区在线直播| 欧美激情第一页xxx| 欧美黄色视屏| 欧美一区二区三区免费观看视频| 亚洲东热激情| 亚洲人成毛片在线播放女女| 欧美肥婆bbw| 久久精品视频在线播放| 欧美精品日韩| 欧美精选午夜久久久乱码6080| 久久免费高清| 乱码第一页成人| 美女啪啪无遮挡免费久久网站| 一区二区三区高清不卡| 亚洲性夜色噜噜噜7777| 国产主播精品| 欧美性做爰猛烈叫床潮| 亚洲国产日韩在线| 亚洲精选91| 99爱精品视频| 蜜臀久久久99精品久久久久久| 久久免费精品日本久久中文字幕| 欧美激情在线狂野欧美精品| 亚洲欧美日韩中文在线制服| 亚洲视频免费在线| 亚洲制服av| 国产精品久久久久久久9999| 欧美一区二区三区视频免费播放 | 欧美一区二区三区在线视频| 伊人激情综合| 亚洲国产色一区| 久久久久88色偷偷免费| 国产欧美一区视频| 一本色道久久综合亚洲91| 亚洲综合精品一区二区| 国产精品久久综合| 国产手机视频精品| 亚洲午夜免费福利视频| 久久精品视频免费播放| 欧美高清在线| 久久久999| 欧美电影免费观看高清| 一区二区电影免费在线观看| 国产欧美视频一区二区| 久久久亚洲综合| 91久久国产综合久久91精品网站| 国产精品99久久久久久久久| 国产婷婷色一区二区三区| 欧美成人一区二区在线 | 91久久精品www人人做人人爽| 欧美日韩在线直播| 久热精品视频在线观看| 亚洲制服av| 日韩一区二区精品在线观看| 久久亚洲视频| 亚洲欧美日韩在线一区| 亚洲国内在线| 黄色成人免费观看| 国产精品久久午夜夜伦鲁鲁| 欧美乱大交xxxxx| 能在线观看的日韩av| 午夜视频久久久| 中国成人黄色视屏| 99精品热6080yy久久| 亚洲国产cao|