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

【AHOI2013復(fù)仇】BZOJ2165

Posted on 2013-01-01 15:39 Mato_No1 閱讀(539) 評論(0)  編輯 收藏 引用 所屬分類: BZOJ
原題地址
2013年第一題……紀(jì)念一下……

設(shè)F[i][j]表示坐i次電梯到達(dá)房間j,最多能到幾樓,則有
F[i][j]=max{F[i-1][k]+W[k][j]}, 0<=k<n;
這里W[k][j]要注意,如果不存在從k到j(luò)的電梯,W[k][j]應(yīng)設(shè)為-INF。
這個方程顯然是可以用矩陣乘法來優(yōu)化的。
然后,問題就是求出最小的i使得F[i]的狀態(tài)中有值>=M的,這個可以二分(每次看當(dāng)前解與W的(2^K-1)次方的運(yùn)算結(jié)果,若有解則實際不進(jìn)行這次運(yùn)算,否則與W的2^K次方運(yùn)算)……總時間復(fù)雜度是O(n3logM)的,對于本題可能要進(jìn)行一些常數(shù)優(yōu)化才能過(20個點(diǎn),每個點(diǎn)5個數(shù)據(jù),相當(dāng)于100個點(diǎn),時限只有40s),反正本沙茶是卡線過的。

但是,本題有一個細(xì)節(jié)很重要,必須要說一下(因為本沙茶在這里卡了1h+)……那就是溢出問題……
F[i][j]的值是有可能超過long long的范圍的,然而如果硬加高精度的話穩(wěn)T,這時,在進(jìn)行矩陣乘法(實際是加法)的時候,需要特判一下,如果這個和超過了INF(INF是~0Ull>>2,>1018),就取INF。這樣可能會破壞結(jié)合律,但是木有事,因為若兩個加數(shù)都是非負(fù)數(shù),則不會破壞,若有負(fù)數(shù),則一定表示無解(-INF),這個特判一下就行了(若兩個加數(shù)之中有負(fù)數(shù),則結(jié)果取-INF)。

代碼:
#include <iostream>
#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<string.h>
using namespace std;
#define re(i, n) for (int i=0; i<n; i++)
#define re1(i, n) for (int i=1; i<=n; i++)
#define re2(i, l, r) for (int i=l; i<r; i++)
#define re3(i, l, r) for (int i=l; i<=r; i++)
#define rre(i, n) for (int i=n-1; i>=0; i--)
#define rre1(i, n) for (int i=n; i>0; i--)
#define rre2(i, r, l) for (int i=r-1; i>=l; i--)
#define rre3(i, r, l) for (int i=r; i>=l; i--)
#define ll long long
const int MAXN = 110, MAXLEN = 61;
const ll INF = ~0Ull >> 2;
int n;
ll M, A[MAXLEN][MAXN][MAXN], W0[MAXN][MAXN], _[MAXN][MAXN], res;
void mult(ll A0[][MAXN], ll B0[][MAXN])
{
    re(i, n) re(j, n) _[i][j] 
= -INF; ll __;
    re(i, n) re(j, n) re(k, n) 
if (A0[i][k] >= 0 && B0[k][j] >= 0) {
        __ 
= A0[i][k] + B0[k][j];
        
if (__ > INF) __ = INF;
        
if (__ > _[i][j]) _[i][j] = __;
    }
}
void prepare()
{
    re2(i, 
1, MAXLEN) {
        mult(A[i 
- 1], A[i - 1]);
        re(j, n) re(k, n) A[i][j][k] 
= _[j][k];
        mult(A[i], A[
0]);
        re(j, n) re(k, n) A[i][j][k] 
= _[j][k];
    }
}
void solve()
{
    re(i, n) re(j, n) 
if (i == j) W0[i][j] = 0else W0[i][j] = -INF; bool FF; res = 0;
    rre(i, MAXLEN) {
        FF 
= 0; re(j, n) if (A[i][0][j] >= M) {FF = 1break;}
        
if (FF) continue;
        mult(W0, A[i]);
        FF 
= 0; re(j, n) if (_[0][j] >= M) {FF = 1break;}
        
if (!FF) {
            re(j, n) re(k, n) W0[j][k] 
= _[j][k];
            mult(W0, A[
0]);
            re(j, n) re(k, n) W0[j][k] 
= _[j][k];
            res 
+= 2ll << i;
        }
    }
    FF 
= 0; re(i, n) if (W0[0][i] >= M) {FF = 1break;}
    
if (!FF) res++;
}
int main()
{
    
int tests;
    scanf(
"%d"&tests);
    re(testno, tests) {
        cin 
>> n >> M;
        re(i, n) re(j, n) {scanf(
"%lld"&A[0][i][j]); if (!A[0][i][j]) A[0][i][j] = -INF;}
        prepare();
        solve();
        cout 
<< res << endl;
    }
    
return 0;
}

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲第一狼人社区| 国产一区二区三区在线观看免费视频| 亚洲大片精品永久免费| 欧美专区在线观看| 欧美在线一级va免费观看| 性欧美1819性猛交| 老**午夜毛片一区二区三区| 免费欧美在线视频| 91久久在线| 亚洲午夜视频在线| 久久久久久日产精品| 欧美激情按摩| 国产精品揄拍500视频| 在线观看日韩国产| 99精品国产福利在线观看免费| 亚洲直播在线一区| 久久亚洲欧洲| 亚洲精品美女在线观看| 亚洲女性裸体视频| 欧美va天堂在线| 国产精品久久久一区二区| 韩日精品视频| 亚洲视频第一页| 欧美成人中文字幕在线| 一区二区三区国产精华| 久久乐国产精品| 国产精品欧美久久| 亚洲三级免费| 久久久国产精品一区二区中文| 亚洲国产欧美国产综合一区| 亚洲欧美日韩另类| 欧美日韩一区二区视频在线观看| 国户精品久久久久久久久久久不卡| 99re66热这里只有精品4| 久久人人九九| 亚洲一线二线三线久久久| 欧美电影免费观看网站| 狠狠色狠色综合曰曰| 亚洲女性裸体视频| 亚洲人妖在线| 久久五月天婷婷| 国产精品综合网站| 亚洲视频一二| 亚洲区国产区| 欧美a级一区| 亚洲福利视频三区| 久久一区激情| 欧美一区二区三区电影在线观看| 欧美日韩亚洲一区二| 亚洲卡通欧美制服中文| 免费一级欧美片在线播放| 日韩午夜剧场| 亚洲黄色片网站| 久久综合色8888| 影音先锋久久| 欧美大香线蕉线伊人久久国产精品| 香港成人在线视频| 国产精品日韩久久久| 亚洲无线一线二线三线区别av| 亚洲国产欧美国产综合一区| 欧美大片一区二区| 99精品欧美一区二区三区综合在线| 欧美福利一区| 欧美黄色aaaa| 中日韩视频在线观看| 亚洲免费福利视频| 欧美视频在线观看视频极品| 亚洲图片在线观看| 亚洲永久免费av| 国产色综合网| 裸体丰满少妇做受久久99精品| 久久国内精品视频| 亚洲国产va精品久久久不卡综合| 免费成人高清视频| 欧美~级网站不卡| av成人手机在线| 亚洲婷婷在线| 国内伊人久久久久久网站视频| 久久这里只有| 欧美国产视频一区二区| 一区二区黄色| 欧美一区二区三区四区在线观看地址 | 亚洲国产精品女人久久久| 欧美电影免费观看高清| 欧美激情一区二区三区蜜桃视频| 一区二区三区视频在线 | 欧美一区二区三区视频在线观看| 亚洲欧美国产日韩中文字幕| 精东粉嫩av免费一区二区三区| 欧美激情在线| 国产精品欧美激情| 欧美xart系列在线观看| 欧美三级乱码| 久久夜色撩人精品| 欧美天天视频| 美女诱惑一区| 国产精品ⅴa在线观看h| 麻豆精品在线观看| 国产精品白丝黑袜喷水久久久| 久久婷婷综合激情| 欧美午夜片欧美片在线观看| 麻豆久久精品| 国产毛片一区| 亚洲免费av观看| 精品成人国产在线观看男人呻吟| 亚洲精品视频在线观看网站| 国产亚洲精品aa| 一区二区免费看| 亚洲国产综合视频在线观看| 亚洲欧美另类中文字幕| 欧美视频一区二区三区在线观看| 久久精品动漫| 国产精品a久久久久| 91久久精品一区二区三区| 国产亚洲精品福利| 一级日韩一区在线观看| 亚洲人成免费| 久热re这里精品视频在线6| 亚洲欧美日韩另类精品一区二区三区 | 欧美成人中文字幕在线| 国产农村妇女精品| 亚洲乱码视频| 亚洲日韩成人| 麻豆国产精品一区二区三区| 久久精品男女| 国产九九精品| 午夜精品福利在线观看| 亚洲专区在线| 欧美日韩一区二区在线视频| 亚洲国产另类久久久精品极度| 国模精品一区二区三区| 亚洲欧美福利一区二区| 午夜在线成人av| 国产精品久久久一区二区三区| 日韩天堂av| 亚洲男人av电影| 国产精品成人在线观看| 日韩视频一区二区三区| 99精品视频免费观看| 欧美日韩免费看| 一区二区日韩免费看| 亚洲欧美激情精品一区二区| 国产精品国产三级国产aⅴ9色| 99天天综合性| 欧美一级艳片视频免费观看| 国产精品一区二区三区免费观看| 亚洲一区二区三区四区五区午夜 | 亚洲日本视频| 欧美日韩1080p| 日韩亚洲欧美成人| 亚洲欧美日韩精品综合在线观看| 国产精品视频一二三| 欧美一级理论性理论a| 久久综合九色综合久99| 亚洲国产精品va在线看黑人| 欧美精品激情blacked18| 99国产精品视频免费观看一公开| 亚洲综合99| 好吊色欧美一区二区三区视频| 久久综合五月天婷婷伊人| 亚洲国产精品黑人久久久 | 欧美成年人视频| 一二美女精品欧洲| 国产欧美精品日韩精品| 久久久噜噜噜久久中文字幕色伊伊| 欧美顶级少妇做爰| 亚洲一级二级| 黄色精品在线看| 欧美精品在线免费播放| 亚洲欧美成人网| 亚洲第一天堂av| 午夜亚洲福利| 亚洲国产午夜| 欧美一区二视频| 亚洲成人中文| 欧美一区二区日韩一区二区| 在线欧美不卡| 国产精品福利在线观看网址| 久久精品中文字幕一区| 99精品国产福利在线观看免费 | 91久久精品国产91性色| 亚洲综合视频1区| 在线观看久久av| 国产精品高潮久久| 欧美成人一区二区三区在线观看 | 久久蜜桃av一区精品变态类天堂| 亚洲精品1234| 国产一区二区日韩精品欧美精品| 欧美精品啪啪| 久久亚洲视频| 欧美综合国产精品久久丁香| 99亚洲精品| 亚洲精品自在久久| 欧美激情在线免费观看| 久久免费99精品久久久久久| 亚洲欧美www| 亚洲图片欧美日产| 亚洲伦理在线免费看| 亚洲国产成人高清精品| 国内精品视频在线观看|