愛生氣的書店老板

題目描述

今天秦陋,書店老板有一家店打算試營業(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è)下來下愈,最多有多少客戶能夠感到滿意的數(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.

思路分析

1.暴力法(n^2)

運(yùn)用滑動(dòng)窗口的思想势似,雙重遍歷數(shù)組,依次比較,找出最大值履因。

class Solution {
    public int maxSatisfied(int[] customers, int[] grumpy, int X) {
        int n=customers.length;
        int k=0;int sum=0;
        //沒有秘密武器時(shí)的滿意度
        for(int customer:customers){
            sum+=customer*(1-grumpy[k++]);
        }
        int[] dp=new int[n];int max=0;
        for(int i=X-1;i<n;i++){
            dp[i]=sum;
            //依次遍歷
            for(int j=i;j>=i-X+1;j--){
                if(grumpy[j]==1) dp[i]+=customers[j];
            }
            max=Math.max(max,dp[i]);
        }
        return max;
    }
}

2.滑動(dòng)窗口優(yōu)化

當(dāng)沒有秘密武器時(shí)障簿,滿意度等于


當(dāng)有秘密武器時(shí),額外滿意度為


class Solution {
    public int maxSatisfied(int[] customers, int[] grumpy, int X) {
        int n=customers.length;
        int sum=0;int k=0;
        //沒有秘密武器
        for(int customer:customers){
            sum+=customer*(1-grumpy[k++]);
        }
        int increase=0;
        //初始increase
        for(int i=0;i<X;i++){
            increase+=customers[i]*grumpy[i];
        }
        int max=increase;
        //遞推公式
        for(int i=X;i<n;i++){
            increase+=customers[i]*grumpy[i]-customers[i-X]*grumpy[i-X];
            max=Math.max(max,increase);
        }
        return sum+max;
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末栅迄,一起剝皮案震驚了整個(gè)濱河市站故,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌霞篡,老刑警劉巖世蔗,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件端逼,死亡現(xiàn)場(chǎng)離奇詭異朗兵,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)顶滩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門余掖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人礁鲁,你說我怎么就攤上這事盐欺。” “怎么了仅醇?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵冗美,是天一觀的道長。 經(jīng)常有香客問我析二,道長粉洼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任叶摄,我火速辦了婚禮属韧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蛤吓。我一直安慰自己宵喂,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布会傲。 她就那樣靜靜地躺著锅棕,像睡著了一般。 火紅的嫁衣襯著肌膚如雪淌山。 梳的紋絲不亂的頭發(fā)上裸燎,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天,我揣著相機(jī)與錄音艾岂,去河邊找鬼顺少。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的脆炎。 我是一名探鬼主播梅猿,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼秒裕!你這毒婦竟也來了袱蚓?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤几蜻,失蹤者是張志新(化名)和其女友劉穎喇潘,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體梭稚,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡颖低,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了弧烤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片忱屑。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖暇昂,靈堂內(nèi)的尸體忽然破棺而出莺戒,到底是詐尸還是另有隱情,我是刑警寧澤急波,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布从铲,位于F島的核電站,受9級(jí)特大地震影響澄暮,放射性物質(zhì)發(fā)生泄漏名段。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一赏寇、第九天 我趴在偏房一處隱蔽的房頂上張望吉嫩。 院中可真熱鬧,春花似錦嗅定、人聲如沸自娩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忙迁。三九已至,卻和暖如春碎乃,著一層夾襖步出監(jiān)牢的瞬間姊扔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來泰國打工梅誓, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留恰梢,地道東北人佛南。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像嵌言,于是被迫代替她去往敵國和親嗅回。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

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