2021.2.23每日一題

1052. 愛生氣的書店老板

今天捺癞,書店老板有一家店打算試營(yíng)業(yè) customers.length 分鐘。每分鐘都有一些顧客(customers[i])會(huì)進(jìn)入書店拦耐,所有這些顧客都會(huì)在那一分鐘結(jié)束后離開婶希。
在某些時(shí)候溉愁,書店老板會(huì)生氣。 如果書店老板在第 i 分鐘生氣饲趋,那么 grumpy[i] = 1拐揭,否則 grumpy[i] = 0。 當(dāng)書店老板生氣時(shí)奕塑,那一分鐘的顧客就會(huì)不滿意堂污,不生氣則他們是滿意的。
書店老板知道一個(gè)秘密技巧龄砰,能抑制自己的情緒盟猖,可以讓自己連續(xù) X 分鐘不生氣,但卻只能使用一次换棚。
請(qǐng)你返回這一天營(yíng)業(yè)下來式镐,最多有多少客戶能夠感到滿意的數(shù)量。

示例:

輸入:customers = [1,0,1,2,1,1,7,5], grumpy = [0,1,0,1,0,1,0,1], X = 3
輸出:16
解釋:
書店老板在最后 3 分鐘保持冷靜固蚤。
感到滿意的最大客戶數(shù)量 = 1 + 1 + 1 + 1 + 7 + 5 = 16.

題解:

本題考查的是滑動(dòng)窗口娘汞,其長(zhǎng)度固定為X。
首先這種思想?yún)⒖嫉氖牵?a target="_blank">這位大佬
我們需要查找這么一個(gè)長(zhǎng)度為X的窗口:窗口內(nèi)能留住更多的原本因?yàn)槔习迳鷼舛悔s走的顧客夕玩。最終最多能滿意的顧客數(shù)量=窗口內(nèi)留住的顧客最大值+所有不生氣時(shí)間的顧客你弦。

    public int maxSatisfied(int[] customers, int[] grumpy, int X) {
        int n = customers.length;
        int sum = 0; //不生氣時(shí)間的顧客總數(shù)
        for (int i = 0; i < n; i++) {
            if (grumpy[i] == 0) {
                sum += customers[i];
            }
        }
        int curValue = 0; //當(dāng)前窗口內(nèi)不滿意顧客的數(shù)量
        for (int i = 0; i < X; i++) {  //前K分鐘不滿意顧客數(shù)量
            if (grumpy[i] == 1) {
                curValue += customers[i];
            }
        } 
        int resValue = curValue; 
        for (int i = X; i < n; i++) { //開始滑動(dòng)窗口
            if (grumpy[i] == 1) {  //新進(jìn)入窗口的元素
                curValue += customers[i];
            }
            if (grumpy[i - X] == 1) { //離開窗口的元素
                curValue -= customers[i - X];
            }
            resValue = Math.max(resValue, curValue);
        }
        return sum + resValue;
    }

還有另外一種思想:
首先求出[0,X-1]窗口內(nèi)滿意顧客的人數(shù),開始向右滑動(dòng)燎孟,進(jìn)來一個(gè)新的禽作,出去一個(gè),求出滿意顧客的數(shù)量揩页,更新最大值旷偿。

    public int maxSatisfied(int[] customers, int[] grumpy, int X) {
        int ans = 0;
        int sum = 0;
        for (int i = 0; i < X; i++) {   //開始窗口內(nèi)顧客滿意數(shù)量
            sum += customers[i];
        }
        for (int i = X; i < customers.length; i++) {  //開始窗口外顧客滿意數(shù)量
            sum += (grumpy[i] == 0) ? customers[i] : 0;
        }
        ans = sum;
        for (int i = 1; i <= customers.length - X; i++) {
            sum -= customers[i - 1] * grumpy[i - 1];
            sum += customers[i - 1 + X] * grumpy[i - 1 + X];
            ans = Math.max(ans, sum);
        }
        return ans;
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市爆侣,隨后出現(xiàn)的幾起案子萍程,更是在濱河造成了極大的恐慌,老刑警劉巖累提,帶你破解...
    沈念sama閱讀 216,692評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件尘喝,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡斋陪,警方通過查閱死者的電腦和手機(jī)朽褪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門置吓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人缔赠,你說我怎么就攤上這事衍锚。” “怎么了嗤堰?”我有些...
    開封第一講書人閱讀 162,995評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵戴质,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我踢匣,道長(zhǎng)告匠,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,223評(píng)論 1 292
  • 正文 為了忘掉前任离唬,我火速辦了婚禮后专,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘输莺。我一直安慰自己戚哎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,245評(píng)論 6 388
  • 文/花漫 我一把揭開白布嫂用。 她就那樣靜靜地躺著型凳,像睡著了一般。 火紅的嫁衣襯著肌膚如雪嘱函。 梳的紋絲不亂的頭發(fā)上甘畅,一...
    開封第一講書人閱讀 51,208評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音实夹,去河邊找鬼橄浓。 笑死,一個(gè)胖子當(dāng)著我的面吹牛亮航,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播匀们,決...
    沈念sama閱讀 40,091評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼缴淋,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了泄朴?” 一聲冷哼從身側(cè)響起重抖,我...
    開封第一講書人閱讀 38,929評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎祖灰,沒想到半個(gè)月后钟沛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,346評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡局扶,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,570評(píng)論 2 333
  • 正文 我和宋清朗相戀三年恨统,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了叁扫。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,739評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡畜埋,死狀恐怖莫绣,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情悠鞍,我是刑警寧澤对室,帶...
    沈念sama閱讀 35,437評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站咖祭,受9級(jí)特大地震影響掩宜,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜么翰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,037評(píng)論 3 326
  • 文/蒙蒙 一锭亏、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧硬鞍,春花似錦慧瘤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至伐坏,卻和暖如春怔匣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背桦沉。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工每瞒, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人纯露。 一個(gè)月前我還...
    沈念sama閱讀 47,760評(píng)論 2 369
  • 正文 我出身青樓剿骨,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親埠褪。 傳聞我的和親對(duì)象是個(gè)殘疾皇子浓利,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,647評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容