Problem
Given a char array representing tasks CPU need to do. It contains capital letters A to Z where different letters represent different tasks.Tasks could be done without original order. Each task could be done in one interval. For each interval, CPU could finish one task or just be idle.
However, there is a non-negative cooling interval n that means between two same tasks, there must be at least n intervals that CPU are doing different tasks or just be idle.
You need to return the least number of intervals the CPU will take to finish all the given tasks.
Example:Input: tasks = ["A","A","A","B","B","B"], n = 2 Output: 8 Explanation: A -> B -> idle -> A -> B -> idle -> A -> B.Note:
The number of tasks is in the range [1, 10000].
The integer n is in the range [0, 100].
class Solution { public int leastInterval(char[] tasks, int n) { int[] records = new int[26]; for (char ch: tasks) { records[ch-"A"]++; } Arrays.sort(records); int i = 25; while (i >= 0 && records[i] == records[25]) i--; return Math.max(tasks.length, (records[25]-1)*(n+1) + (25-i)); } }Using counter
class Solution { public int leastInterval(char[] tasks, int n) { int[] records = new int[26]; int max = 0, maxCount = 0; for (char ch: tasks) { records[ch-"A"]++; if (records[ch-"A"] == max) maxCount++; else if (records[ch-"A"] > max) { maxCount = 1; max = records[ch-"A"]; } } int parts = (n+1) * (max-1); int part = maxCount; return Math.max(tasks.length, parts+part); } }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/71842.html
摘要:接下來,就看怎么用協(xié)程來實現(xiàn)異步了。直接拿的原始寫代碼會死人的。引入?yún)f(xié)程就是為了把上下連續(xù)的業(yè)務(wù)邏輯放在一個協(xié)程里,把與業(yè)務(wù)關(guān)系不大的的處理部分放到框架的里。第三部分是放棄掉執(zhí)行權(quán)。這樣一個只能接收打印一行的異步應(yīng)用就寫好了。 前面已經(jīng)準(zhǔn)備好了greenlet對應(yīng)的Java版本了,一個刪減后的kilim(http://segmentfault.com/blog/taowen/11900...
摘要:基本上所有的網(wǎng)絡(luò)應(yīng)用都會示范一個的寫法。除了這些操作的主體是而不是,操作的是,而不是。以為例其過程是這樣的這段代碼就是創(chuàng)建一個,并注冊一個,并把附著到上。關(guān)鍵之一顯然是利用了協(xié)程的和,把回調(diào)轉(zhuǎn)換成順序的邏輯執(zhí)行。 基本上所有的網(wǎng)絡(luò)應(yīng)用都會示范一個tcp的echo寫法。前面我們已經(jīng)看到了如何使用協(xié)程和異步io來做tcp服務(wù)器的第一步,accept。下面是一個完整的echo server的...
摘要:包主要實現(xiàn)類,這是一個抽象類,實現(xiàn)了通用的模板方法,并在方法內(nèi)部判斷錯誤重試去重處理等。重置重復(fù)檢查就是清空,獲取請求總數(shù)也就是獲取的。至于請求總數(shù)統(tǒng)計,就是返回中維護的的大小。 Scheduler是Webmagic中的url調(diào)度器,負責(zé)從Spider處理收集(push)需要抓取的url(Page的targetRequests)、并poll出將要被處理的url給Spider,同時還負責(zé)...
摘要:還可以看到任務(wù)運行的開始時間,結(jié)束時間,運行時間,點擊就可以看到這個任務(wù)執(zhí)行詳情,包括有向無環(huán)圖,和或節(jié)點具體的運行記錄。 摘要: MaxCompute(原ODPS)的概念 海量數(shù)據(jù)處理平臺,服務(wù)于批量結(jié)構(gòu)化數(shù)據(jù)的存儲和計算,提供海量數(shù)據(jù)倉庫的解決方案以及針對大數(shù)據(jù)的分析建模服務(wù).(官方文檔有這里就不多做介紹了)官方文檔鏈接 優(yōu)勢 用戶不必關(guān)心分布式計算細節(jié),從而達到分析大數(shù)據(jù)的目的。...
閱讀 3318·2023-04-25 19:42
閱讀 1336·2021-11-23 10:11
閱讀 2274·2021-11-16 11:51
閱讀 1598·2019-08-30 15:54
閱讀 2043·2019-08-29 18:44
閱讀 1624·2019-08-23 18:24
閱讀 497·2019-08-23 17:52
閱讀 1772·2019-08-23 15:33