Luogu P2690 接蘋果

來源:互聯網
上載者:User

標籤:輸入輸出   無法   mil   stdout   name   cout   etc   microsoft   max   

題目背景

USACO

題目描述

很少有人知道奶牛愛吃蘋果。農夫約翰的農場上有兩棵蘋果樹(編號為1和2), 每一棵樹上都長滿了蘋果。奶牛貝茜無法摘下樹上的蘋果,所以她只能等待蘋果 從樹上落下。但是,由於蘋果掉到地上會摔爛,貝茜必須在半空中接住蘋果(沒有人愛吃摔爛的蘋果)。貝茜吃東西很快,她接到蘋果後僅用幾秒鐘就能吃完。每一分鐘,兩棵蘋果樹其中的一棵會掉落一個蘋果。貝茜已經過了足夠的訓練, 只要站在樹下就一定能接住這棵樹上掉落的蘋果。同時,貝茜能夠在兩棵樹之間 快速移動(移動時間遠少於1分鐘),因此當蘋果掉落時,她必定站在兩棵樹其中的一棵下面。此外,奶牛不願意不停地往返於兩棵樹之間,因此會錯過一些蘋果。蘋果每分鐘掉落一個,共T(1<=T<=1000)分鐘,貝茜最多願意移動W(1<=W<=30) 次。現給出每分鐘掉落蘋果的樹的編號,要求判定貝茜能夠接住的最多蘋果數。 開始時貝茜在1號樹下。

輸入輸出格式

輸入格式:

 

第一行2個數,t和k。接下來的t行,每行一個數,代表在時刻t蘋果是從1號蘋果樹還是從2號蘋果樹上掉下來的。

 

輸出格式:

 

對於每個測試點,輸出一行,一個數,為奶牛最多接到的蘋果的數量。

 

輸入輸出範例 輸入範例#1:
7 22112211
輸出範例#1:解題思路:

主要思路:這道題是一道很簡單的記憶化搜尋的題目.

 

我們可以這樣想:每次只有兩種決策,就是換位置或者不換.

 

我們得知道哪一種能得到的蘋果數最多,我們就選哪一種.

 

這樣,我們就可以看出了這道題的子問題.

 

我們可以用DP[i][j][k]來表示在第i個時間上,轉換了j次位置,現在在k,最多能拿到多少蘋果?

 

狀態轉移方程就出來了:DP[i][j][k]=max(DP[i+1][j+1][3-k],DP[i+1][j][k]).

 

但是要注意,如果當前這個點能夠吃到蘋果的話,蘋果數還得加一.

 

//這是記憶化搜尋!#include<bits/stdc++.h>using namespace std;int read(){int ret=0,ok=1;char ch=getchar();while(ch<‘0‘||ch>‘9‘){if(ch==‘-‘)ok=-1;ch=getchar();}for(;ch>=‘0‘&&ch<=‘9‘;ch=getchar()) ret=ret*10+ch-‘0‘;return ret*ok;}int t,k;int a[5500];int dp[2500][2500][3];inline int dfs(int time,int sum,int now)//time是現在的時間,sum是換了幾次位置,now是現在的位置{    if(time>t||sum>k)//如果越界    {        return 0;    }    if(dp[time][sum][now]!=0)//如果已經求過解    {        return dp[time][sum][now];    }    dp[time][sum][now]=max(dfs(time+1,sum+1,3-now),dfs(time+1,sum,now));//前者是換位置,後者是不換    if(a[time]==now)//如果當前這個位置當前這個時間能吃到蘋果    {        dp[time][sum][now]++;//蘋果數加一    }    return dp[time][sum][now];//返回 }int main(){//freopen("apple.in","r",stdin);//freopen("apple.out","w",stdout);t=read(),k=read();for(int i=1;i<=t; i++){a[i]=read(); }dfs(1,0,1); cout<<dp[1][0][1];    return 0;}
//這是DP#include<bits/stdc++.h>using namespace std;int read(){int ret=0,ok=1;char ch=getchar();while(ch<‘0‘||ch>‘9‘){if(ch==‘-‘)ok=-1;ch=getchar();}for(;ch>=‘0‘&&ch<=‘9‘;ch=getchar()) ret=ret*10+ch-‘0‘;return ret*ok;}int a[5000];int t,k;int dp[2500][3];int main(){//freopen("apple.in","r",stdin);//freopen("apple.out","w",stdout);t=read(),k=read();for(int i=1;i<=t;i++){    a[i]=read();}for(int i=1;i<=t;i++){    for(int j=k;j>=0;j--)    {        if(j>0)        {            dp[j][a[i]]=max(dp[j][a[i]]+1,dp[j-1][3-a[i]]+1);        }        else if(a[i]==1)        dp[j][a[i]]++;    }}cout<<max(dp[k][1],dp[k][2]);    return 0;}

 

 

Luogu P2690 接蘋果

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.