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

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

HDU 2227 Find the nondecreasing subsequences

題目鏈接:http://acm.hdu.edu.cn/showproblem.php?pid=2227
/*
題意:
    給定N(N <= 100000)個數字ai,找出這個序列中有多少非遞減序列。

解法:
樹狀數組 + 動態規劃

思路:
    如果n的值小于等于1000,我們可以用動態規劃來解,dp[i]表示
到第i個位置能夠找到的非遞減序列的解的數量,那么有狀態轉移方程
dp[i] = sum{ dp[j], j<i, a[j]<=a[i] },這個時間復雜度是O(n^2)
,但是n很大,所以不能采用,但是我們觀察到這個轉移方程是以求和
的形式出現,并且有一個限制條件就是a[j] <= a[i],那么如果我們把
數字映射到下標,就可以輕松的通過樹狀數組的成段求和來統計了。
    具體做法是:由于數字較大,我們可以先將所有數字離散化,這樣
每個數字就有一個 <= n 的標號,然后這個標號就可以對應樹狀數組的
下標了,每次從左往右在樹狀數組中統計比當前數小或者相等的數的個
數,然后將當前數字(離散后的數字)插入到樹狀數組中,循環結束,
累加和就是最后的答案了。

*/


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

typedef unsigned 
int ui;
typedef __int64 ll;

#define maxn 100010
#define mod 1000000007

int n;
ui val[maxn], t[maxn];
ll c[maxn];
int tot;

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


void add(int pos, ll v) {
    
while(pos <= tot) {
        c[pos] 
+= v; if(c[pos] >= mod ) c[pos] %= mod;
        pos 
+= lowbit(pos);
    }

}


ll sum(
int pos) {
    
int s = 0;
    
while(pos >= 1{
        s 
+= c[pos]; if(s >= mod ) s %= mod;
        pos 
-= lowbit(pos);
    }

    
return s;
}


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

}


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

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

        }

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

        ll ans 
= 0;
        add(
11);
        
for(i = 0; i < n; i++{
            ll x 
= sum(val[i]);
            ans 
+= x;  if(ans >= mod) ans %= mod;
            add(val[i], x);
        }

        printf(
"%d\n", (int)ans);
    }

    
return 0;
}

posted on 2011-04-06 12:11 英雄哪里出來 閱讀(1500) 評論(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>
            国产欧美日韩另类一区| 亚洲激情不卡| 极品少妇一区二区三区精品视频| 欧美日韩精品一区二区三区| 欧美日韩天堂| 国产精品麻豆成人av电影艾秋| 国产精品久久97| 国产嫩草一区二区三区在线观看 | 久久免费黄色| 女女同性精品视频| 亚洲经典三级| 亚洲欧美不卡| 巨胸喷奶水www久久久免费动漫| 欧美成人资源网| 国产精品丝袜xxxxxxx| 狠狠色狠狠色综合日日五| 日韩亚洲欧美在线观看| 欧美亚洲日本网站| 亚洲高清在线播放| 欧美一区二区黄色| 欧美人妖另类| 在线观看欧美亚洲| 欧美一区三区二区在线观看| 欧美一区二视频| 亚洲第一视频| 亚洲欧洲精品一区| 亚洲一区二区毛片| 欧美激情二区三区| 亚洲日韩欧美视频| 欧美在线观看一区二区| 国产欧美日韩综合一区在线观看 | 久久精品视频在线看| 亚洲二区在线视频| 欧美日韩国内| 亚洲午夜高清视频| 亚洲自拍三区| 亚洲视频在线一区| 欧美在线观看www| 久久精品在线视频| 国产精品国产福利国产秒拍| 黑人巨大精品欧美黑白配亚洲| 欧美激情视频在线免费观看 欧美视频免费一| 欧美一区二区三区免费看| 欧美中文字幕在线播放| 欧美精品免费视频| 欧美亚洲尤物久久| 国产精品久久影院| 亚洲无人区一区| 亚洲人成在线播放网站岛国| 亚洲性感美女99在线| 亚洲综合色在线| 欧美精品一区二区三区四区| 欧美日韩国产一中文字不卡| 国产三区精品| 亚洲在线视频观看| 国产精品免费看片| 久久久99精品免费观看不卡| 亚洲在线免费视频| 国产香蕉97碰碰久久人人| 亚洲黄一区二区三区| 欧美一区二区三区的| 国产精品一区在线观看| 欧美三级电影精品| 一本大道久久a久久综合婷婷| 亚洲国产日韩欧美在线图片| 久久成人精品视频| 理论片一区二区在线| 久久久久网站| 狠狠爱成人网| 美女任你摸久久| 久久人人爽国产| 亚洲国产精品传媒在线观看 | 亚洲黄色av| 欧美人与禽猛交乱配视频| 在线视频亚洲一区| 夜夜爽99久久国产综合精品女不卡 | 麻豆成人小视频| 久久久久久久波多野高潮日日| 激情视频一区二区| 另类图片国产| 欧美精品一区在线| 亚洲午夜av在线| 欧美综合第一页| 最新国产拍偷乱拍精品| 欧美成人一区二免费视频软件| 欧美www视频| 亚洲一区免费看| 午夜欧美理论片| 在线观看日韩国产| 亚洲毛片一区二区| 国产无遮挡一区二区三区毛片日本| 久久综合九色99| 欧美日本国产精品| 久久精品国产久精国产一老狼| 久久九九电影| 99综合视频| 久久国产主播| 亚洲天天影视| 久久成人精品| 美脚丝袜一区二区三区在线观看| 99国产精品久久久久老师| 亚洲欧美成人综合| 亚洲激情小视频| 亚洲免费影院| 欧美亚洲免费在线| 激情另类综合| 91久久国产综合久久蜜月精品 | 亚洲电影免费观看高清完整版| 欧美日韩国产页| 欧美一区二区三区在线观看视频| 麻豆国产精品777777在线| 午夜激情综合网| 欧美美女bb生活片| 久久久久一区二区| 国产精品卡一卡二| 亚洲午夜91| 欧美高清视频免费观看| 久久久久久久网| 欧美午夜电影网| 亚洲欧洲日产国产综合网| 精品成人在线视频| 小黄鸭精品密入口导航| 亚洲女同精品视频| 欧美激情综合色综合啪啪| 噜噜噜躁狠狠躁狠狠精品视频| 国产欧美1区2区3区| 一区二区高清在线| 国产精品99久久久久久白浆小说 | 一区免费视频| 欧美影院成年免费版| 欧美一区二区三区在线观看视频| 欧美性生交xxxxx久久久| 麻豆成人av| 亚洲在线中文字幕| 免费日韩av电影| 美女日韩在线中文字幕| 国内激情久久| 久久aⅴ国产紧身牛仔裤| 欧美一区二区黄| 午夜在线精品偷拍| 亚洲国产成人在线播放| 亚洲欧美文学| 国产精品久久国产三级国电话系列| 亚洲欧洲日本专区| 在线视频精品| 国产精品久久久久毛片大屁完整版| 99精品视频免费观看视频| 亚洲国产精品一区二区第一页 | 国内免费精品永久在线视频| 亚洲一区中文字幕在线观看| 亚洲欧美综合国产精品一区| 国产精品久久网站| 亚洲在线视频免费观看| 欧美三级欧美一级| 亚洲自拍偷拍网址| 久久精品视频免费播放| 黄色另类av| 你懂的一区二区| 一区二区成人精品| 久热精品视频在线观看| 亚洲韩国日本中文字幕| 欧美日韩成人在线| 香港久久久电影| 亚洲第一搞黄网站| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产精品人人做人人爽人人添| 欧美在线播放一区二区| 亚洲成色精品| 欧美一区二区三区视频在线观看| 伊人狠狠色j香婷婷综合| 欧美老女人xx| 久久国产日韩| 一区二区三区毛片| 欧美成人黄色小视频| 亚洲欧美日韩国产综合| 精品电影在线观看| 国产精品久久激情| 欧美成人免费全部| 性欧美videos另类喷潮| 亚洲国产精品一区二区尤物区| 久久www成人_看片免费不卡| 日韩午夜中文字幕| 激情婷婷欧美| 欧美无乱码久久久免费午夜一区 | 国产精品稀缺呦系列在线| 免费一级欧美在线大片| 亚洲综合日韩| 99视频超级精品| 亚洲黄页视频免费观看| 久久久亚洲欧洲日产国码αv| 亚洲色图自拍| 日韩一级免费观看| 亚洲国产精品999| 国产一区亚洲| 国产精品视频精品视频| 欧美日韩在线大尺度| 欧美激情一级片一区二区| 久久久久成人精品| 欧美一区成人| 亚洲欧美日韩成人高清在线一区|