青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Topcoer SRM 453.5

Posted on 2009-12-11 19:59 rikisand 閱讀(230) 評論(0)  編輯 收藏 引用 所屬分類: Topcoder 、Algorithm

一直沒寫,補上上次的srm~

250pt

500pt 隊列BFS

Code Snippet
template<class T> void getMin(T& a,T b){if(b<a)a=b;}
template<class T> void getMax(T& a,T b){if(b>a)a=b;}
#define REP(i, n) for (int i = 0; i < (n); ++i)
#define inf 98765432
int mp[55][55];
struct node{
    int c;
    int r;
    int value;
    node(int rr,int cc,int vv):r(rr),c(cc),value(vv){}
};
class MazeMaker
{
        public:
        int longestPath(vector <string> maze, int sRow, int sCol, vector <int> mRow, vector <int> mCol)
        {
                int R=maze.size();
                int C=maze[0].size();
                REP(i,R)REP(j,C)mp[i][j]=inf;
                deque<node> q;
                q.push_back(node(sRow,sCol,0));
                while(!q.empty()){
                    node now=q.front();
                    q.pop_front();
                    int r=now.r;int c=now.c ;int v=now.value;
                    if( mp[r][c]!=inf)continue;
                    mp[r][c]=v;
                    for(int i=0;i<mRow.size();i++){
                        int nr=r+mRow[i];int nc=c+mCol[i];
                        if(nr<0||nr>=R||nc<0||nc>=C||mp[nr][nc]!=inf||maze[nr][nc]=='X')continue;
                        q.push_back(node(nr,nc,v+1));
                    }
                }
                int res=-1;
                REP(i,R)REP(j,C){
                    if(maze[i][j]=='.'){
                        if(mp[i][j] == inf)return -1;
                        if(mp[i][j]>res)res=mp[i][j];
                    }
                }
                return res;
        }

DFS也可以

VS mp;
VI mR,mC;int N,R,C; 
int used[55][55];
void DFS(int r,int c,int len){
    REP(i,mR.size()){
        int nr=r+mR[i];int nc=c+mC[i];
        if(nr<0||nr>=R||nc<0||nc>=C||mp[nr][nc]=='X')continue;
        if(used[nr][nc]<=len+1)continue;
        used[nr][nc]=len+1;
        DFS(nr,nc,len+1);
    }
}
class MazeMaker
{
        public:
        int longestPath(vector <string> maze, int sRow, int sCol, vector <int> moveRow, vector <int> moveCol)
        {
                mR=moveRow;mC=moveCol;mp=maze;
                R=maze.size();C=maze[0].size();
                REP(i,R)REP(j,C)used[i][j]=inf;
                used[sRow][sCol]=0;
                DFS(sRow,sCol,0);
                int res=-1;
                REP(i,R)REP(j,C){
                    if(mp[i][j]=='.'){
                        if(used[i][j]==inf)return -1;
                        if(used[i][j]>res)res=used[i][j];
                    }
                }
                return res;
        }

1000pt

實際為求從中取出K個數字,連續兩個間的序號差不能大于maxDist 求能夠求得的最大乘積

由于有負數的存在,最大數字的取得可能是最大的乘以最大的,或者最大的乘以最小的(正 負相乘)

因此要保存到每一個數為止,作為第k個數,取得的最大最小值,dp求解之

 

Code Snippet
typedef long long int64;   

template<class T> void getMin(T& a,T b){if(b<a)a=b;}
template<class T> void getMax(T& a,T b){if(b>a)a=b;}
#define REP(i, n) for (int i = 0; i < (n); ++i)
int64 dp[55][55][2];//µÚ¼¸¸ö£¬ÓÃÁ˼¸¸ö£¬Õý»¹ÊǸº;
#define inf 133
class TheProduct
{
        public:
        long long maxProduct(vector <int> infm, int _K, int maxD)
        {
            int N = infm.size();
            memset(dp,-1,sizeof(-1));
            REP(i,N)REP(j,51)REP(c,2)dp[i][j][c]=inf;
            REP(i,N)  dp[i][0][0]=dp[i][0][1]=(int64)infm[i];
            
            for(int i=0;i<N;i++)
                for(int j=i-1;i-j<=maxD && j>=0;j--)
                    for(int z=0;z<_K;z++){
                        if(dp[j][z][0]!=inf){
                            if(dp[i][z+1][0]==inf||dp[j][z][0]*infm[i]<dp[i][z+1][0])dp[i][z+1][0]=dp[j][z][0]*infm[i];
                            if(dp[i][z+1][1]==inf||dp[j][z][0]*infm[i]>dp[i][z+1][1])dp[i][z+1][1]=dp[j][z][0]*infm[i];
                        }
                        if(dp[j][z][1]!=inf){
                            if(dp[i][z+1][0]==inf||dp[j][z][1]*infm[i]<dp[i][z+1][0])dp[i][z+1][0]=dp[j][z][1]*infm[i];
                            if(dp[i][z+1][1]==inf||dp[j][z][1]*infm[i]>dp[i][z+1][1])dp[i][z+1][1]=dp[j][z][1]*infm[i];
                        }
                    }
            int64 res=-(1LL<<63);
            REP(i,N){
                if(dp[i][_K-1][1]!=inf)
                 getMax(res,dp[i][_K-1][1]);    
            }
            return res;
        }

 

 

 

 

 

 

 

 

 

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产自产v一区二区三区c| 夜夜狂射影院欧美极品| 亚洲国产成人av好男人在线观看| 欧美午夜精品一区| 欧美日韩一区视频| 欧美性大战久久久久| 国产精品video| 国产欧美日韩亚洲| 国产一级久久| 另类av一区二区| 老司机久久99久久精品播放免费| 久久久水蜜桃| 欧美精品18+| 国产精品www| 国内外成人在线| 亚洲精品国精品久久99热一| 在线综合亚洲欧美在线视频| 午夜精品美女自拍福到在线 | 精品51国产黑色丝袜高跟鞋| 在线视频观看日韩| 亚洲免费成人| 午夜精品久久| 免费观看久久久4p| 99精品国产一区二区青青牛奶| 中国成人在线视频| 久久综合九色综合欧美狠狠| 亚洲综合精品自拍| 国产欧美一区二区三区国产幕精品| 国产亚洲一区在线播放| 亚洲国产精品小视频| 亚洲夜晚福利在线观看| 久久久久久久97| 亚洲人成在线播放| 亚洲一区二区网站| 欧美暴力喷水在线| 国产日韩av一区二区| 亚洲精品在线二区| 老司机午夜精品视频| 99国内精品久久| 久久综合激情| 国产欧美一区二区精品性| 一本色道久久| 欧美成人一品| 欧美一区二区三区免费视| 欧美日韩一区在线播放| 亚洲国产成人在线视频| 欧美有码在线观看视频| 99成人在线| 欧美福利小视频| 狠狠综合久久av一区二区小说 | 欧美视频一二三区| 亚洲日韩欧美视频一区| 久久一区二区精品| 亚洲一区久久久| 欧美日韩国产区一| 亚洲人成毛片在线播放女女| 久久在精品线影院精品国产| 亚洲欧美国产一区二区三区| 欧美视频精品在线| 一区二区三区高清在线| 亚洲日本一区二区三区| 欧美88av| 亚洲国产影院| 欧美搞黄网站| 老司机午夜精品| 亚洲激情不卡| 亚洲国产成人porn| 欧美福利视频在线| 亚洲美女黄网| 亚洲精品资源美女情侣酒店| 欧美日韩福利视频| 亚洲尤物视频网| 亚洲天堂av高清| 国产精品无人区| 久久精品一本| 久久久久一本一区二区青青蜜月| 国产综合18久久久久久| 久久综合九色九九| 久久男人资源视频| 亚洲国产一区视频| 亚洲精品乱码久久久久久久久| 欧美人与禽猛交乱配视频| 欧美日韩大陆在线| 欧美视频福利| 午夜精品一区二区三区在线| 亚洲一区二三| 国产一区在线免费观看| av成人免费在线观看| 9l国产精品久久久久麻豆| 国产精品女同互慰在线看| 久久久99爱| 欧美丰满高潮xxxx喷水动漫| 亚洲一区二区在线播放| 欧美一区二区视频免费观看| 在线观看欧美视频| 最新亚洲一区| 国产精自产拍久久久久久| 久久伊人精品天天| 欧美精品123区| 欧美在线亚洲一区| 久久久午夜电影| 99这里只有久久精品视频| 欧美亚洲系列| 亚洲精品视频中文字幕| 亚洲一区在线播放| 亚洲国产日韩欧美在线图片| 亚洲私拍自拍| 亚洲欧洲一二三| 午夜亚洲视频| 在线亚洲+欧美+日本专区| 久久精品亚洲一区二区三区浴池| 99热在这里有精品免费| 午夜一区二区三视频在线观看| 亚洲精品看片| 久久不射中文字幕| 亚洲女女女同性video| 欧美成人免费网| 久久久久久久久久久久久9999| 欧美极品欧美精品欧美视频| 欧美中文字幕| 欧美性jizz18性欧美| 欧美黄色一级视频| 国产日韩精品一区二区| 一本色道久久综合亚洲精品不 | 久久一区二区视频| 久久精品国产欧美激情| 国产精品久线观看视频| 日韩视频精品| 日韩亚洲欧美中文三级| 欧美91福利在线观看| 欧美高清成人| 最近看过的日韩成人| 久久婷婷国产综合国色天香| 久久久在线视频| 国产在线播精品第三| 欧美一区二区网站| 欧美主播一区二区三区美女 久久精品人| 欧美日韩小视频| 亚洲日本在线视频观看| 日韩网站在线观看| 欧美另类69精品久久久久9999| 亚洲国产二区| 一本到12不卡视频在线dvd | 狠狠狠色丁香婷婷综合久久五月| 欧美精品一区二区高清在线观看| 亚洲天堂成人在线观看| 日韩午夜在线| 久久午夜国产精品| 欧美成人按摩| 亚洲第一狼人社区| 久久黄金**| 欧美国产一区二区| 精品动漫一区二区| 欧美一区二区精品久久911| 激情欧美一区二区三区在线观看| 欧美在线观看天堂一区二区三区| 亚洲午夜视频在线| 欧美精品一卡二卡| 亚洲精品日韩在线| 欧美在线视屏 | 国产精品久久久久影院亚瑟| 亚洲免费精品| 亚洲天堂久久| 国产综合在线看| 久久免费观看视频| 欧美刺激午夜性久久久久久久| 欧美精品一区二区三区蜜臀| 一本色道久久综合狠狠躁篇怎么玩| 亚洲视频一区二区| 欧美日韩中文精品| 国产精品99久久久久久久久 | 欧美四级电影网站| 一区二区三区日韩欧美| 久久在线播放| 极品少妇一区二区| 老鸭窝亚洲一区二区三区| 农夫在线精品视频免费观看| 亚洲国产精品尤物yw在线观看| 欧美国产日产韩国视频| av成人福利| 午夜视频在线观看一区| 国产日韩精品一区二区三区在线| 欧美中日韩免费视频| 欧美刺激午夜性久久久久久久| 在线观看亚洲精品视频| 欧美日韩xxxxx| 在线亚洲欧美视频| 久久久久久久久岛国免费| 在线观看日韩国产| 欧美精品三级日韩久久| 亚洲视频日本| 久久综合一区二区三区| 久久久久国产精品一区三寸 | 亚洲欧美日韩天堂| 免费欧美在线视频| 亚洲午夜国产成人av电影男同| 国产美女扒开尿口久久久| 欧美视频一二三区| 欧美在线日韩| 亚洲人成网站999久久久综合|