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

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數據加載中……

PKU 3378 Crazy Thairs

題目鏈接:http://poj.org/problem?id=3378
/*
題意:
    給定N (1 <= N <= 50000) 個小于等于10^9的數Ai, 要求找出Crazy Thair的數量。
Crazy Thair是一個五元組{i, j, k, l, m}滿足: 
1. 1 <= i < j < k < l < m <= N
2. Ai < Aj < Ak < Al < Am 

解法:
    樹狀數組

思路:
    可以參考以下這題的解法:
http://m.shnenglu.com/menjitianya/archive/2011/04/06/143510.html
    那一題求得是非遞減數列的數量,沒有要求元素個數,這題是要求元素個數一定要
是5個,我們還是可以寫出狀態轉移方程:
dp[i][j] = sum{ dp[i-1][k], k<j, a[k] < a[j] } dp[i][j]表示長度為i以j結尾的
序列的數量,這題需要建立5個樹狀數組,sum這一步操作就可以通過樹狀數組的成段求
和來做。每次求i-1的滿足情況的解,完畢后就將答案插入到i的樹狀數組中。
    當長度為5的時候就是最后的答案了,累加即可。
*/

#include 
<iostream>
#include 
<algorithm>
using namespace std;

typedef 
int hugeint;
const int Base = 10000
const int Capacity = 7;

struct xnum {
    
int Len;
    
int Data[Capacity];
    xnum() : Len(
0{}
    xnum(
const xnum& V) : Len(V.Len) {
        memcpy(Data, V.Data, Len 
* sizeof *Data);
    }

    xnum(
int V) : Len(0
        
for (; V > 0; V /= Base) Data[Len++= V % Base;
    }

    xnum(
char S[]);
    xnum
& operator=(const xnum& V) 
        Len 
= V.Len;
        memcpy(Data, V.Data, Len 
* sizeof *Data); 
        
return *this;
    }

    
int& operator[](int Index) return Data[Index]; }
    
int operator[](int Index) const return Data[Index]; }
    
void print(){
        printf(
"%d",Len==0?0:Data[Len-1]);
        
for(int i=Len-2;i>=0;i--)
            
for(int j=Base/10;j>0;j/=10)
                printf(
"%d",Data[i]/j%10);
    }

}
;

xnum::xnum(
char S[]) {
    
int I, J;
    Data[Len 
= 0= 0;
    J 
= 1;
    
for (I = strlen(S)-1; I>=0; I--{
        Data[Len] 
+= (S[I] - '0'* J;
        J 
*= 10;
        
if (J >= Base) J = 1, Data[++Len] = 0;
    }

    
if (Data[Len] > 0) Len++;
}


int compare(const xnum& A, const xnum& B) {
    
int I;
    
if (A.Len != B.Len) return A.Len > B.Len ? 1 : -1;
    
for (I = A.Len - 1; I >= 0 && A[I] == B[I]; I--);
    
if (I < 0return 0;
    
return A[I] > B[I] ? 1 : -1;
}


xnum 
operator+(const xnum& A, const xnum& B) {
    xnum R;
    
int I;
    
int Carry = 0;
    
for (I = 0; I < A.Len || I < B.Len || Carry > 0; I++)
    
{
        
if (I < A.Len) Carry += A[I];
        
if (I < B.Len) Carry += B[I];
        R[I] 
= Carry % Base;
        Carry 
/= Base;
    }

    R.Len 
= I;
    
return R;
}


xnum 
operator-(const xnum& A, const xnum& B) {
    xnum R;
    
int Carry = 0;
    R.Len 
= A.Len;
    
int I;
    
for (I = 0; I < R.Len; I++{
        R[I] 
= A[I] - Carry;
        
if (I < B.Len) R[I] -= B[I];
        
if (R[I] < 0) Carry = 1, R[I] += Base;
        
else Carry = 0;
    }

    
while (R.Len > 0 && R[R.Len - 1== 0) R.Len--;
    
return R;
}


xnum 
operator*(const xnum& A, const int B) {
    
int I;
    
if (B == 0return 0;
    xnum R;
    hugeint Carry 
= 0;
    
for (I = 0; I < A.Len || Carry > 0; I++)
    
{
        
if (I < A.Len) Carry += hugeint(A[I]) * B;
        R[I] 
= Carry % Base;
        Carry 
/= Base;
    }

    R.Len 
= I;
    
return R;
}


xnum 
operator*(const xnum& A, const xnum& B) {
    
int I;
    
if (B.Len == 0return 0;
    xnum R;
    
for (I = 0; I < A.Len; I++{
        hugeint Carry 
= 0;
        
for (int J = 0; J < B.Len || Carry > 0; J++{
            
if (J < B.Len) Carry += hugeint(A[I]) * B[J];
            
if (I + J < R.Len) Carry += R[I + J];
            
if (I + J >= R.Len) R[R.Len++= Carry % Base;
            
else R[I + J] = Carry % Base;
            Carry 
/= Base;
        }
   
    }

    
return R;
}


xnum 
operator/(const xnum& A, const int B) {
    xnum R;
    
int I;
    hugeint C 
= 0;
    
for (I = A.Len - 1; I >= 0; I--)
    
{
        C 
= C * Base + A[I];
        R[I] 
= C / B;
        C 
%= B;
    }

    R.Len 
= A.Len;
    
while (R.Len > 0 && R[R.Len - 1== 0) R.Len--;
    
return R;
}


xnum 
operator/(const xnum& A, const xnum& B) {
    
int I;
    xnum R, Carry 
= 0;
    
int Left, Right, Mid;
    
for (I = A.Len - 1; I >= 0; I--{
        Carry 
= Carry * Base + A[I];
        Left 
= 0;
        Right 
= Base - 1;
        
while (Left < Right) {
            Mid 
= (Left + Right + 1/ 2;
            
if (compare(B * Mid, Carry) <= 0) Left = Mid;
            
else Right = Mid - 1;
        }

        R[I] 
= Left;
        Carry 
= Carry - B * Left;
    }

    R.Len 
= A.Len;
    
while (R.Len > 0 && R[R.Len - 1== 0) R.Len--;
    
return R;
}


xnum 
operator%(const xnum& A, const xnum& B) {
    
int I;
    xnum R, Carry 
= 0;
    
int Left, Right, Mid;
    
for (I = A.Len - 1; I >= 0; I--{
        Carry 
= Carry * Base + A[I];
        Left 
= 0;
        Right 
= Base - 1;
        
while (Left < Right) {
            Mid 
= (Left + Right + 1/ 2;
            
if (compare(B * Mid, Carry) <= 0) Left = Mid;
            
else Right = Mid - 1;
        }

        R[I] 
= Left;
        Carry 
= Carry - B * Left;
    }

    R.Len 
= A.Len;
    
while (R.Len > 0 && R[R.Len - 1== 0) R.Len--;
    
return Carry;
}


istream
& operator>>(istream& In, xnum& V) {
    
char Ch;
    
for (V = 0; In >> Ch;) {
        V 
= V * 10 + (Ch - '0');
        
if (cin.peek() <= ' 'break;
    }

    
return In;
}


ostream
& operator<<(ostream& Out, const xnum& V) {
    
int I;
    Out 
<< (V.Len == 0 ? 0 : V[V.Len - 1]);
    
for (I = V.Len - 2; I >= 0; I--
        
for (int J = Base / 10; J > 0; J /= 10
            Out 
<< V[I] / J % 10;
        
return Out;
}


xnum gcd(xnum a,xnum b) 
{
    
if(compare(b,0)==0return a;
    
else return gcd(b,a%b); 
}


int div(char *A,int B) {
    
int I;
    
int C = 0;
    
int Alen=strlen(A);
    
for (I = 0; I <Alen; I++)
    
{
        C 
= C * Base + A[I]-'0';
        C 
%= B;
    }

    
return C;
}


#define maxn 50010

int n;
xnum c[
6][maxn];
int val[maxn], bin[maxn], tot;

int lowbit(int x) {
    
return x & (-x);
}


void add(int idx, int pos, xnum v) {
    
while(pos <= n) {
        c[idx][pos] 
= c[idx][pos] + v;
        pos 
+= lowbit(pos);
    }

}


xnum sum(
int idx, int pos) {
    xnum s 
= 0;
    
while(pos > 0{
        s 
= s + c[idx][pos];
        pos 
-= lowbit(pos);
    }

    
return s;
}


int Bin(int v) {
    
int l = 1;
    
int r = tot;
    
while(l <= r) {
        
int m = (l + r) >> 1;
        
if(bin[m] == v)
            
return m;
        
if(v > bin[m]) {
            l 
= m + 1;
        }
else
            r 
= m - 1;
    }

}



int main() {
    
int i, j;
    
while(scanf("%d"&n) != EOF) {
        tot 
= 0;
        
for(i = 1; i <= n; i++{
            scanf(
"%d"&val[i]);
            bin[i] 
= val[i];
        }

        sort(bin
+1, bin+1+n);
        
for(i = 1; i <= n; i++{
            
if(i==1 || bin[i] != bin[i-1])
                bin[ 
++tot ] = bin[i];
        }

        
for(i = 0; i <= 5; i++{
            
for(j = 1; j <= n; j++)
                c[i][j] 
= 0;
        }


        
for(i = 1; i <= n; i++{
            val[i] 
= Bin(val[i]);
        }

        xnum ans 
= 0;
        
for(i = 1; i <= n; i++{
            add(
1, val[i], 1);
            
for(j = 2; j <= 5; j++{
                xnum p 
= sum(j-1, val[i]-1);
                
if(p.Len)
                    add(j, val[i], p);

                
if(j == 5{
                    ans 
= ans + p;
                }

            }

        }

        ans.print();
        puts(
"");
    }

    
return 0;
}

posted on 2011-04-07 13:16 英雄哪里出來 閱讀(1521) 評論(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>
            欧美激情一区二区三区蜜桃视频| 亚洲国产精品传媒在线观看| 欧美一区二区三区在线看 | 亚洲精美视频| 蜜臀久久99精品久久久画质超高清| 久久久精品免费视频| 久久夜色精品亚洲噜噜国产mv| 蘑菇福利视频一区播放| 亚洲精品资源| 午夜久久资源| 欧美va亚洲va国产综合| 欧美三级免费| 亚洲一区免费网站| 久久男女视频| 欧美色图五月天| 在线播放日韩| 午夜伦理片一区| 欧美激情第1页| 亚洲一区二区动漫| 久久在线播放| 国产精品一区久久久| 亚洲国产视频直播| 午夜精品福利在线| 亚洲国产精品成人| 欧美一级电影久久| 欧美日韩国产美女| 在线观看一区二区精品视频| 中文高清一区| 免费试看一区| 性色一区二区三区| 欧美日韩a区| 另类av一区二区| 国产精品另类一区| 亚洲人精品午夜在线观看| 欧美一级视频免费在线观看| 亚洲国产日本| 久久视频在线视频| 国产综合第一页| 欧美中文在线视频| 宅男噜噜噜66一区二区| 欧美精品少妇一区二区三区| 一区二区在线视频观看| 国产精品理论片在线观看| 在线亚洲+欧美+日本专区| 欧美一区午夜精品| 一区二区三区高清不卡| 欧美岛国在线观看| 亚洲缚视频在线观看| 久久精品亚洲精品| 亚洲女人av| 国产精品区二区三区日本 | 欧美精品三级| 亚洲精品久久久久久久久| 免费成年人欧美视频| 欧美在线视频免费观看| 国产精品亚洲综合久久| 亚洲男人av电影| 一区二区高清视频在线观看| 欧美国产在线视频| 夜久久久久久| 一区二区冒白浆视频| 欧美日韩在线播放一区二区| 一本色道久久综合狠狠躁篇的优点 | 亚洲精品视频中文字幕| 欧美freesex8一10精品| 久热精品视频在线观看一区| 亚洲黄色免费| 最近中文字幕日韩精品| 欧美日韩免费在线观看| 午夜精品亚洲一区二区三区嫩草| 亚洲一区美女视频在线观看免费| 国产伦精品一区二区三区视频黑人| 欧美一区二区三区久久精品茉莉花 | 一区二区三区久久| 亚洲视频图片小说| 红桃视频国产精品| 亚洲人成亚洲人成在线观看| 欧美肉体xxxx裸体137大胆| 午夜久久福利| 久久久之久亚州精品露出| 99精品热视频| 性欧美在线看片a免费观看| 亚洲国产福利在线| 亚洲视频日本| 亚洲国产另类 国产精品国产免费| 亚洲国产精品久久久久秋霞影院| 欧美色道久久88综合亚洲精品| 久久精品人人做人人综合| 欧美99久久| 久久精品视频在线播放| 免费欧美在线视频| 欧美亚洲视频| 欧美精品久久天天躁 | 亚洲激情社区| 亚洲人成绝费网站色www| 国产精品一区二区黑丝| 蜜臀久久久99精品久久久久久| 欧美国内亚洲| 欧美在线中文字幕| 欧美日韩另类视频| 免费不卡在线观看| 国产日韩欧美二区| 亚洲精品永久免费精品| 在线观看日韩欧美| 亚洲永久在线观看| 一区二区三区av| 开元免费观看欧美电视剧网站| 亚洲午夜成aⅴ人片| 欧美第一黄网免费网站| 模特精品裸拍一区| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲夜晚福利在线观看| 日韩一级黄色av| 欧美成人dvd在线视频| 久久久亚洲人| 国产一区二区三区奇米久涩| 中文在线资源观看视频网站免费不卡| 1000部国产精品成人观看| 亚洲先锋成人| 午夜国产精品影院在线观看| 欧美全黄视频| 亚洲高清不卡av| 亚洲国产二区| 你懂的亚洲视频| 欧美激情精品久久久久久黑人| 韩日视频一区| 久久国产精品色婷婷| 久久久精品2019中文字幕神马| 国产欧美日韩精品一区| 午夜精品福利视频| 久久精品视频在线看| 国产亚洲a∨片在线观看| 亚洲一区欧美激情| 久久精品一区二区| 黑丝一区二区三区| 久久网站免费| 亚洲国产精品美女| 999在线观看精品免费不卡网站| 欧美成年人网站| 亚洲美女尤物影院| 午夜精彩国产免费不卡不顿大片| 国产精品免费小视频| 午夜视频在线观看一区二区三区| 久久精品国产精品 | 欧美gay视频激情| 亚洲精品乱码久久久久久黑人| 在线亚洲美日韩| 国产精品五区| 久久精品一本| 91久久精品网| 亚洲女同同性videoxma| 国产私拍一区| 欧美成在线观看| 亚洲尤物在线视频观看| 久久夜色精品国产| 亚洲精品1区| 国产精品久久久久aaaa九色| 欧美诱惑福利视频| 亚洲欧洲美洲综合色网| 欧美一区二区精品久久911| 性高湖久久久久久久久| 国产午夜精品久久久久久久| 久久精品国产亚洲高清剧情介绍| 久久在线精品| 亚洲影音先锋| 1024成人| 国产精品高潮呻吟久久av黑人| 久久成人免费日本黄色| 亚洲精品专区| 麻豆九一精品爱看视频在线观看免费| 亚洲精品久久久蜜桃| 国产精品一区二区在线| 欧美国产精品久久| 欧美一区国产二区| 日韩一区二区精品在线观看| 久久久久欧美| 亚洲在线观看| 亚洲精品一二三| 国内精品国语自产拍在线观看| 欧美日韩国产成人精品| 久久久欧美精品| 午夜精品久久久久久久99樱桃 | 欧美伊人久久| 99在线精品观看| 欧美高清视频在线| 久久久精品免费视频| 亚洲自拍偷拍视频| 亚洲另类春色国产| 一区免费在线| 国产一区二区丝袜高跟鞋图片 | 亚洲中字在线| 亚洲蜜桃精久久久久久久| 男人的天堂亚洲| 久久精彩视频| 欧美在线一二三四区| 欧美一区二区三区日韩| 亚洲制服av| 亚洲影院色在线观看免费| 中文亚洲视频在线| 一区二区三区久久|