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

Topcoer SRM 453.5

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

一直沒寫,補上上次的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>
            男女av一区三区二区色多| 久久国产精彩视频| 国产美女高潮久久白浆| 欧美视频久久| 国产精品一区二区三区免费观看| 欧美视频网址| 国产亚洲一区二区在线观看| 国产一区二区成人| 亚洲二区视频在线| 一本色道精品久久一区二区三区| 亚洲视频一区| 久久天堂av综合合色| 亚洲电影免费在线| 91久久国产精品91久久性色| 亚洲天堂av高清| 久久成年人视频| 欧美精品一区二区蜜臀亚洲| 国产精品蜜臀在线观看| 一区精品久久| 亚洲在线1234| 亚洲第一精品电影| 亚洲欧美日韩国产另类专区| 久久男女视频| 国产精品美女久久久| 亚洲国产精品毛片| 欧美一区二区三区久久精品茉莉花| 裸体歌舞表演一区二区| 宅男噜噜噜66一区二区| 欧美激情中文字幕在线| 欧美精品一卡| 狠狠色狠狠色综合日日五| 亚洲精品系列| 久久亚洲私人国产精品va| 99re8这里有精品热视频免费| 久久精品中文字幕一区| 国产精品进线69影院| 亚洲国产欧美一区二区三区同亚洲| 亚洲图片激情小说| 亚洲国产精品视频一区| 久久久久久69| 国产在线视频欧美一区二区三区| 亚洲视频精品| 亚洲精品系列| 免费日韩一区二区| 激情一区二区三区| 久久成人资源| 午夜精品久久久久久久蜜桃app| 欧美精品在线观看| 亚洲精品一区二区三| 欧美88av| 久久亚洲综合色| 国产一区99| 久久大香伊蕉在人线观看热2| 一区二区三区黄色| 欧美视频在线免费看| 一区二区三区精品视频| 亚洲精品美女在线观看播放| 欧美777四色影视在线| 亚洲激情社区| 最近中文字幕日韩精品 | 欧美成人亚洲| 久久精品国产精品亚洲| 韩国精品一区二区三区| 久久久久综合| 久久久久久一区| 亚洲国产片色| 亚洲精品午夜精品| 欧美午夜片在线观看| 在线视频一区二区| 一区二区三区三区在线| 国产精品青草久久| 久久国产精品久久久| 久久精品综合| 亚洲麻豆国产自偷在线| 一区二区三区视频在线看| 国产精品一级久久久| 久久久精品午夜少妇| 久热精品在线| 一区二区日韩免费看| 亚洲欧美激情四射在线日 | 国内精品写真在线观看| 亚洲欧美日韩专区| 欧美在线视频日韩| 亚洲第一伊人| 日韩手机在线导航| 国产啪精品视频| 欧美韩日一区二区| 欧美三级欧美一级| 久久五月婷婷丁香社区| 模特精品在线| 亚洲欧美日韩天堂| 久久综合激情| 午夜日韩av| 久久网站免费| 亚洲午夜激情在线| 久久久久久久综合狠狠综合| 99re热这里只有精品免费视频| 亚洲一品av免费观看| 在线免费观看视频一区| 亚洲深夜激情| 亚洲黄色天堂| 亚洲欧美日韩国产一区二区| 亚洲精品久久嫩草网站秘色| 亚洲欧美日韩网| 日韩视频永久免费| 久久不射中文字幕| 亚洲综合激情| 欧美激情中文不卡| 开心色5月久久精品| 国产精品久久久久秋霞鲁丝 | 国产精品久久久久久亚洲调教| 久久香蕉国产线看观看av| 欧美性猛片xxxx免费看久爱| 欧美国产激情二区三区| 国产精品夜色7777狼人| 亚洲裸体在线观看| 亚洲人成在线观看网站高清| 欧美在线观看视频在线 | 欧美国产精品劲爆| 国产伊人精品| 亚洲综合电影一区二区三区| 一区二区黄色| 欧美激情视频在线播放| 免费亚洲电影| 亚洲第一成人在线| 久久久久免费| 久久五月天婷婷| 激情成人在线视频| 久久国产精品72免费观看| 久久不射电影网| 国产女主播一区二区三区| 亚洲视频大全| 欧美夜福利tv在线| 国产精品视频一区二区三区| 国产精品99久久久久久久久 | 亚洲国产综合91精品麻豆| 欧美尤物巨大精品爽| 久久精品九九| 韩国一区二区三区在线观看| 欧美一区二区三区久久精品| 欧美一区二区视频97| 这里只有视频精品| 欧美电影在线观看| 欧美激情偷拍| 亚洲七七久久综合桃花剧情介绍| 久久人91精品久久久久久不卡| 久久深夜福利免费观看| 伊人成人开心激情综合网| 久久全国免费视频| 亚洲激情网址| 亚洲男人第一av网站| 国产欧美亚洲日本| 久久九九久久九九| 亚洲黄色影院| 午夜精品偷拍| 伊人久久久大香线蕉综合直播| 久久一区欧美| 亚洲美女视频网| 欧美一区二区三区啪啪| 在线观看av不卡| 欧美v日韩v国产v| 一区二区不卡在线视频 午夜欧美不卡在 | 国产精品xxxxx| 翔田千里一区二区| 欧美gay视频| 亚洲免费小视频| 精品99一区二区| 欧美破处大片在线视频| 亚洲欧美综合精品久久成人| 久久影院亚洲| 中文一区二区| 激情久久久久久久| 欧美日韩在线视频观看| 久久久久久黄| 亚洲视频电影在线| 欧美顶级大胆免费视频| 亚洲欧美一区二区视频| 亚洲国产高清一区| 国产模特精品视频久久久久| 麻豆成人在线观看| 午夜精品久久久久| 99国产精品99久久久久久| 美女在线一区二区| 欧美一区二区日韩| 在线亚洲激情| 91久久久久久国产精品| 国产欧美一区二区三区国产幕精品| 免费观看日韩av| 欧美一区二区三区四区夜夜大片| 最新成人在线| 欧美二区乱c少妇| 久久国产精彩视频| 亚洲欧美日韩综合一区| 99爱精品视频| 亚洲人成在线播放网站岛国| 极品少妇一区二区| 国产专区综合网| 国产日韩成人精品| 国产精品久久久久影院亚瑟| 欧美高清在线观看|