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

vijos1664 真-資源勘探題解

Posted on 2009-10-06 12:28 hyf 閱讀(446) 評(píng)論(2)  編輯 收藏 引用 所屬分類: OI
    這是道怨念題,交了5次都等不到puppy,更詭異的是vj上顯示的是ac……
    題目的大意是給出n*m的矩陣,詢問(1,1)->(x,y)的子矩陣中只出現(xiàn)一次的元素個(gè)數(shù)
    對(duì)于第i行來說,記錄1->i行內(nèi)元素x最小和次小的橫坐標(biāo)x0、x1,那么在該行內(nèi)將元素x記錄進(jìn)去的子矩陣只能是左下坐標(biāo)在x0到(x1-1)之間的。
    所以按行i掃描,維護(hù)(1,1)->(i,x)子矩陣的稀有資源個(gè)數(shù),也就是對(duì)于在本行內(nèi)出現(xiàn)的元素算出其新的區(qū)間[x0,x1),原區(qū)間全部減1,新區(qū)間加1,在該行沒有出現(xiàn)的元素不變。
    區(qū)間整體修改可以用線段樹來維護(hù),但是此題用線段樹T的可能性相當(dāng)大,注意到這里是維護(hù)區(qū)間詢問點(diǎn),所以可以把樹狀數(shù)組逆向運(yùn)用,這樣常數(shù)大大降低。
    最終復(fù)雜度是O(n^2logn),C++還要進(jìn)行輸入優(yōu)化。

囧代碼:
  1 #include <iostream>
  2 using namespace std;
  3 #define LOWBIT(x) (x&(-x))
  4 
  5 int n,m;
  6 int data[1100][1100];
  7 int r[2000000];
  8 int pre[2000000][2];
  9 int hash[2000000][2= {0};
 10 int ans = 0;
 11 int A[1101= {0};
 12 char s[10000];
 13 
 14 void Modify(int x, int c)
 15 {
 16     while(x)
 17     {
 18         A[x] += c;
 19         x -= LOWBIT(x);
 20     }
 21 }
 22 
 23 int Get(int x)
 24 {
 25     int ans = 0;
 26     while(x<=m)
 27     {
 28         ans += A[x];
 29         x += LOWBIT(x);
 30     }
 31     return ans;
 32 }
 33 
 34 void init()
 35 {
 36     int tmp, p;
 37     char *ptr;
 38     scanf("%d %d\n",&n,&m);
 39     for(int i = 0; i < n; i++)
 40     {
 41         gets(s);
 42         p = tmp = 0;
 43         ptr = s;
 44         while(*ptr)
 45         {
 46             if((*ptr)==' ')
 47                 data[i][p++= tmp, tmp = 0;
 48             else
 49                 tmp *= 10, tmp += (*ptr)-'0';
 50             ptr++;
 51         }
 52         data[i][p] = tmp;
 53     }
 54     for(int i = 0; i <= n*m; i++)
 55         hash[i][0= hash[i][1= m, pre[i][0= pre[i][1= m, r[i] = -1;
 56 }
 57 
 58 void solve()
 59 {
 60     int tmp = 0;
 61     for(int i = 0; i < n; i++)
 62     {
 63         for(int j = 0; j < m; j++)
 64         {
 65             tmp = data[i][j];
 66             pre[tmp][0= hash[tmp][0], pre[tmp][1= hash[tmp][1];
 67         }
 68         for(int j = 0; j < m; j++)
 69         {
 70             tmp = data[i][j];
 71             if(j<pre[tmp][0])
 72                 pre[tmp][1= pre[tmp][0], pre[tmp][0= j;
 73             else if(j<pre[tmp][1])
 74                 pre[tmp][1= j;
 75         }
 76         for(int j = 0; j < m; j++)
 77         {
 78             tmp = data[i][j];
 79             if(r[tmp]!=i)
 80             {
 81                 Modify(hash[tmp][1],-1);
 82                 Modify(hash[tmp][0],1);
 83                 Modify(pre[tmp][1],1);
 84                 Modify(pre[tmp][0],-1);
 85                 hash[tmp][0= pre[tmp][0], hash[tmp][1= pre[tmp][1];
 86                 r[tmp] = i;
 87             }
 88         }
 89         for(int j = 1; j <= m; j++)
 90             tmp = Get(j), ans ^= tmp;
 91     }       
 92 }
 93 
 94 void print()
 95 {
 96     printf("%d\n",ans);
 97 }
 98 
 99 int main(void)
100 {
101     init();
102     solve();
103     print();
104     return 0;
105 }

   

Feedback

# re: vijos1664 真-資源勘探題解[未登錄]  回復(fù)  更多評(píng)論   

2009-10-06 21:35 by Tim
orz?
ORZ!

# re: vijos1664 真-資源勘探題解[未登錄]  回復(fù)  更多評(píng)論   

2009-11-27 08:32 by SonicMisora
ORZ!

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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国产精品视频免费观看一公开| 久久久欧美精品sm网站| 国产精品久久久久久妇女6080| 亚洲国产精品久久久久秋霞蜜臀 | 欧美一区国产一区| 亚洲激情黄色| 欧美一区二区三区啪啪| 国产精品久99| 亚洲欧洲偷拍精品| 久久色在线观看| 亚洲制服丝袜在线| 欧美色偷偷大香| 日韩视频在线免费观看| 欧美1区免费| 欧美在线一级视频| 国产精品一页| 亚洲欧美另类在线| 日韩香蕉视频| 欧美激情一区二区在线| 在线国产精品一区| 久久蜜桃香蕉精品一区二区三区| 亚洲欧美99| 国产精品入口日韩视频大尺度| 中文久久精品| 亚洲精品在线二区| 欧美日韩999| 日韩亚洲精品视频| 亚洲黄网站在线观看| 欧美大片在线影院| 亚洲日本视频| 亚洲高清免费| 麻豆成人小视频| 亚洲高清不卡在线观看| 欧美xx视频| 久久亚洲午夜电影| 在线精品视频一区二区三四| 美脚丝袜一区二区三区在线观看| 久久久久久999| 在线国产欧美| 欧美激情第4页| 嫩草成人www欧美| 91久久久一线二线三线品牌| 欧美激情综合色| 蜜臀av性久久久久蜜臀aⅴ| 在线看欧美日韩| 欧美国产日韩精品免费观看| 美女露胸一区二区三区| 亚洲人久久久| 亚洲精品五月天| 欧美午夜在线观看| 香蕉成人久久| 午夜精品久久久久久| 国产亚洲高清视频| 狂野欧美激情性xxxx| 浪潮色综合久久天堂| 亚洲美女啪啪| 9l视频自拍蝌蚪9l视频成人| 国产精品久久久久久户外露出| 亚洲中午字幕| 亚欧成人精品| 在线观看日韩| 亚洲国产欧美在线| 欧美三级电影一区| 欧美一区二区在线播放| 久久久久久一区| 亚洲人妖在线| 亚洲狼人综合| 国产乱码精品1区2区3区| 久久久久久免费| 免费视频一区| 亚洲无线一线二线三线区别av| 亚洲影院色无极综合| 国内精品国产成人| 亚洲国产精品久久久| 国产精品盗摄久久久| 久久久精品免费视频| 欧美成人免费小视频| 亚洲一级在线| 欧美在线一级视频| 亚洲美女诱惑| 亚洲一区久久| 亚洲二区在线| 一区二区三区av| 激情小说另类小说亚洲欧美| 亚洲激精日韩激精欧美精品| 国产精品专区第二| 欧美大片一区| 国产精品videossex久久发布| 久久久综合香蕉尹人综合网| 欧美精品aa| 先锋影音久久久| 免费日韩视频| 久久成人18免费观看| 欧美成人午夜剧场免费观看| 性刺激综合网| 欧美成人视屏| 欧美综合国产| 欧美区在线播放| 久久久91精品国产| 欧美日韩国产成人在线观看| 久久亚洲捆绑美女| 欧美日本韩国| 久久午夜精品| 欧美小视频在线观看| 欧美不卡视频| 国产精品亚洲产品| 91久久精品美女| 国产一区二区毛片| 日韩一级裸体免费视频| 激情视频一区| 亚洲一区在线看| 日韩视频永久免费观看| 欧美资源在线| 亚洲一区二区网站| 欧美不卡视频| 久久―日本道色综合久久| 欧美私人网站| 亚洲国产综合视频在线观看| 国产综合久久久久久鬼色| 一本色道久久综合亚洲精品高清| 在线成人av网站| 午夜精品影院| 亚洲午夜高清视频| 欧美~级网站不卡| 久久久一二三| 国产精品久久精品日日| 91久久综合亚洲鲁鲁五月天| 国产综合自拍| 亚洲欧美高清| 亚洲一区二区三区高清| 欧美福利专区| 麻豆久久婷婷| 国产亚洲美州欧州综合国| 一区二区三区视频在线观看 | 牛人盗摄一区二区三区视频| 久久精品国产综合精品| 国产精品久久国产三级国电话系列 | 国产亚洲午夜高清国产拍精品| 99这里只有久久精品视频| 亚洲美女精品成人在线视频| 老司机免费视频久久| 久久偷窥视频| 国产一区二区看久久| 亚洲欧美日韩国产综合在线| 亚洲性视频网址| 欧美人与禽猛交乱配| 欧美国产日韩一区二区| 亚洲福利视频一区二区| 久久婷婷蜜乳一本欲蜜臀| 久久久综合免费视频| 国产一区二区精品丝袜| 欧美在线视频免费| 久久精品国产综合精品| 国产偷久久久精品专区| 亚洲欧美日韩国产成人| 欧美一区二粉嫩精品国产一线天| 国产精品久久久久久影院8一贰佰 国产精品久久久久久影视 | 欧美成人一区二区三区| 国产主播一区二区三区四区| 欧美一区二区三区在线免费观看| 欧美一区二区三区免费在线看| 国产精品久久久久国产a级| 亚洲婷婷免费| 午夜视频一区在线观看| 国产精品爽爽ⅴa在线观看| 亚洲视频在线观看| 午夜亚洲影视| 国产欧美亚洲视频| 欧美一级日韩一级| 久久国产精品一区二区| 国产一区二区三区高清播放| 欧美主播一区二区三区| 男女视频一区二区| 亚洲激情女人| 欧美精品一区二区三区蜜臀 | 亚洲大片在线| 亚洲日本中文| 欧美人与性动交α欧美精品济南到 | 99精品热6080yy久久| 亚洲一区影音先锋| 国产精品一区二区你懂得| 新狼窝色av性久久久久久| 久久久夜夜夜| 亚洲欧洲在线一区| 欧美片在线观看| 亚洲天堂激情| 久久久一本精品99久久精品66| 亚洲第一毛片| 欧美激情在线狂野欧美精品| 亚洲天堂成人在线观看| 久久久久五月天| 亚洲欧洲综合另类| 欧美三级电影大全| 欧美夜福利tv在线|