日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

队列的实现与应用

發(fā)布時間:2025/10/17 9 豆豆
生活随笔 收集整理的這篇文章主要介紹了 队列的实现与应用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

抽象數(shù)據(jù)類型queue的定義

實現(xiàn)了以下數(shù)據(jù)結(jié)構(gòu)與操作方法的數(shù)據(jù)類型稱為queue

一、隊列的python實現(xiàn)

  • 方法一:標(biāo)準(zhǔn)庫
from queue import Queue

基于list實現(xiàn)

class Queue():def __init__(self):self.items = []def enqueue(self, item):#左邊為rear,右邊為front;即右邊為隊首#insert(0)操作為O(n)self.items.insert(0, item)def dequeue(self):return self.items.pop()def isEmpty(self):return self.items == []def size(self):return len(self.items)

二、隊列應(yīng)用

2.1 hot potato問題

from queue import Queue#熱土豆/擊鼓傳花問題;從0開始數(shù) def hot_potato(players, num):q = Queue()for player in players:q.enqueue(player)while q.size() > 1:for i in range(num):q.enqueue(q.dequeue())q.dequeue()#循環(huán)結(jié)束后,只剩下一個playerreturn q.dequeue()if __name__ == '__main__':print(hot_potato(["Bill","David","Susan","Jane","Kent","Brad"],7))
2.2模擬打印機平均等待時間

  • 每180秒產(chǎn)生一個打印task
  • 每個task打印1-20頁
  • 打印機速率有兩種:10頁/min,5頁/min
  • 求1小時內(nèi)task的平均等待時間(進入隊列到彈出隊列)以及未完成的task數(shù)目

關(guān)鍵:模擬的本質(zhì):for i in range(3600) ,遍歷一次代表1秒,而非真正的時間戳

from queue import Queue from random import randrangeclass Printer():def __init__(self, pagerate):#參數(shù)1:當(dāng)前處理任務(wù)剩余秒數(shù);參數(shù)2:當(dāng)前任務(wù)對象;參數(shù)3:每分鐘打印張數(shù)self.seconds_ramianing = 0self.current_task = Noneself.pagerate = pageratedef start_task(self,task):self.current_task = taskself.seconds_ramianing = task.get_page()* 60/self.pageratedef tick(self):#減小一個點數(shù);消耗一秒if self.current_task != None:self.seconds_ramianing -= 1if self.seconds_ramianing == 0:self.current_task = Nonedef busy(self):return self.current_task != Noneclass Task():def __init__(self, current_time):self.page = randrange(1,21)self.timestamp = current_timedef wait_time(self,current_time):return current_time - self.timestampdef get_page(self):return self.pagedef task_appear():#隨機發(fā)生器,看能否在【1,180】內(nèi)命中180,命中即判定該秒發(fā)生了一個task#該函數(shù)執(zhí)行平均180次有一次成功num = randrange(1,181)return num == 180def simulation(sum_seconds,pages_per_min):#參數(shù)1:總的模擬時間;參數(shù)2:打印機速率printer = Printer(pages_per_min)task_queue = Queue()wait_times = []for i in range(sum_seconds):#秒為最小模擬單位#模擬task是否產(chǎn)生if task_appear():newtask = Task(i)task_queue.enqueue(newtask)#模擬是否提交task隊列中的taskif not printer.busy() and not task_queue.isEmpty():current_task = task_queue.dequeue()wait_times.append(current_task.wait_time(i))printer.start_task(current_task)#printer計時也要減小printer.tick()#計算平均等待時間ave_wait_time = sum(wait_times)/len(wait_times)print('Average waiting time is {}, and {} tasks remaining!'.format(ave_wait_time,task_queue.size()))if __name__ == '__main__':for i in range(10):simulation(3600, 5)print('*'*100)for i in range(10):simulation(3600, 10)

總結(jié)

以上是生活随笔為你收集整理的队列的实现与应用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 免费成人看视频 | 国产又粗又猛又黄视频 | 伊人情人综合 | 日韩福利电影在线观看 | 婷婷视频 | 国产精品视频一区二区三区不卡 | 男女野外做受全过程 | www.一级片| 男人天堂手机在线 | 色哟哟国产精品 | 亚洲人无码成www久久 | 日韩成人免费视频 | 草比视频在线观看 | 一起操网站 | 波多野结衣中文字幕一区二区三区 | 国产tv在线观看 | www.色人阁.com | 亚洲午夜精品久久久久久浪潮 | 欧美视频直播网站 | 动漫av在线 | 亚洲成色网 | 日本xxxx18高清hd | 色秀视频在线观看 | 黄色a级片视频 | 久久精品无码人妻 | 性囗交免费视频观看 | 精国产人伦一区二区三区 | 亚洲无色| 色香蕉av | 女性爱爱视频 | 伊人久久久久久久久 | 熟妇女人妻丰满少妇中文字幕 | 精品亚洲乱码一区二区 | 久久人人妻人人人人妻性色av | 欧美体内谢she精2性欧美 | 黑人干亚洲人 | 火影黄动漫免费网站 | 中文字幕自拍偷拍 | www.av网| www网站在线免费观看 | 午夜免费毛片 | 色哟哟一区 | 91在线精品一区二区三区 | 午夜视频在线网站 | 伊人在线视频 | 欧洲成人一区二区三区 | 岛国精品 | 毛片福利视频 | 亚洲精品视频大全 | 国产精品永久免费视频 | jizz在线免费观看 | 国产精品日韩一区二区三区 | 国产精品成人久久电影 | 精品美女在线 | 专干中国老太婆hd | 黄色理论片 | 一级片视频网站 | 成人福利av | 另类小说一区二区 | 日韩在线观看你懂的 | 免费三级大片 | 日本天堂网在线观看 | 8x8ⅹ成人永久免费视频 | 99精品在线观看视频 | 成人在线观看一区二区三区 | 色哟哟网站在线观看 | 九色国产视频 | 午夜日韩av | 国产精品99久久久久久宅男 | 偷拍一区二区三区四区 | 射久久 | 天堂福利视频 | 男人扒女人添高潮视频 | 国产综合一区二区 | 好吊妞视频在线 | 亚州春色 | 亚洲AV成人无码一二三区在线 | 毛片网站免费观看 | 成年人视频在线播放 | 国产成人在线视频免费观看 | 嫩草综合 | 免费看黄av | 69xav| 男人的天堂伊人 | 精品日韩在线播放 | 精品人妻一区二区三区四区五区 | 麻豆系列在线观看 | 美女户外露出 | 永久免费网站直接看 | 欧美一区二区在线视频观看 | 亚洲精品乱码久久久久久蜜桃不卡 | 91亚洲一区| 欧美一级大片免费看 | av毛片大全 | 国产免费不卡 | 在线cao | 激情五月综合网 | 毛片大全在线观看 | 黄色成人在线网站 |