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

心如止水
Je n'ai pas le temps
posts - 400,comments - 130,trackbacks - 0
題目大意:給出了兩個操作:1、C A B D,將區間[A,B]賦值為D;2、P A B,輸出區間[A,B]中有多少個不同的數。
一上午時間,極度郁悶地完成了這道題,原因是看漏了一個條件:At the beginning,the board was painted in color 1.結果我卻認為一開始是沒有顏色的……
數據規模L=100000,肯定需要一個O(nlogn)的算法,于是需要在O(logn)內完成插入和查詢操作,考慮線段樹。
最多只有30種顏色,可以用long整數表示一個區間的顏色:二進制。用按位或運算就可以實現集合的合并。
以下是我的代碼:
#include<stdio.h>
const long maxL=100007;
typedef 
struct
{
    
long a,b;
    unsigned 
long color;
    
long left,right;
}node;
long L,T,O,tot;
node tree[maxL
*7];
void swap(long &a,long &b)
{
    
long t=a;a=b;b=t;
}
long kind(unsigned long color)
{
//  How many colors in Color
    long re=0;
    
for(long i=1;i<=T;i++)
      
if(color&(1<<i))
        re
++;
    
return re;
}
void build(long begin,long end)
{
//  Build A Segment Tree
    long now,mid=(begin+end)>>1;
    tot
++;now=tot;
    tree[now].a
=begin;tree[now].b=end;tree[now].color=2;
    
if(begin<end)
    {
       tree[now].left
=tot+1;build(begin,mid);
       tree[now].right
=tot+1;build(mid+1,end);
    }
}
void insert(long x,long y,long c,long node)
{
//  Insert
    long a=tree[node].a,b=tree[node].b,t=(a+b)>>1;
    
if(x<=a&&b<=y)
      tree[node].color
=(1<<c);
    
else
    {
       
//------
       if(kind(tree[node].color)<=1)
         tree[tree[node].left].color
=tree[tree[node].right].color=tree[node].color;
       
//------
       if(t>=x)
         insert(x,y,c,tree[node].left);
       
if(t+1<=y)
         insert(x,y,c,tree[node].right);
       tree[node].color
=tree[tree[node].left].color|tree[tree[node].right].color;
    }
}
unsigned 
long getcol(long x,long y,long node)
{
//  return color(s) of [x,y]
    long l=0,r=0,a=tree[node].a,b=tree[node].b,t=(a+b)>>1;
    
if(kind(tree[node].color)<=1)
      
return tree[node].color;
    
if(x<=a&&b<=y)
      
return tree[node].color;
    
if(t>=x)
      l
=getcol(x,y,tree[node].left);
    
if(t+1<=y)
      r
=getcol(x,y,tree[node].right);
    
return l|r;
}
int main()
{
    scanf(
"%ld%ld%ld",&L,&T,&O);getchar();
    tot
=0;
    build(
1,L);
    
for(long i=1;i<=O;i++)
    {
       
char cmd;
       
long a,b,c;
       cmd
=getchar();
       
       
switch(cmd)
       {
          
case 'C':
             scanf(
"%ld%ld%ld",&a,&b,&c);getchar();
             
if(a>b) swap(a,b);
             insert(a,b,c,
1);
             
break;
          
case 'P':
             scanf(
"%ld%ld",&a,&b);getchar();
             
if(a>b) swap(a,b);
             printf(
"%ld\n",kind(getcol(a,b,1)));
             
break;
       }
    }
return 0;
}


posted on 2010-02-18 13:38 lee1r 閱讀(1087) 評論(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>
            最新国产成人在线观看| 欧美中文字幕不卡| 欧美一区二区三区在线| 亚洲视频电影在线| 一本色道久久综合狠狠躁篇怎么玩| 亚洲国产成人精品视频| 在线看无码的免费网站| 亚洲电影第1页| 亚洲高清色综合| 日韩一级视频免费观看在线| av不卡在线| 欧美一区二区三区四区在线观看地址| 性欧美videos另类喷潮| 男人的天堂亚洲| 99国内精品| 久久精品国产清自在天天线| 久久美女艺术照精彩视频福利播放| 久久一区二区三区四区五区| 欧美日韩mv| 国产伊人精品| 99视频精品免费观看| 久久激情五月丁香伊人| 欧美激情一区在线观看| 亚洲女性裸体视频| 欧美 日韩 国产一区二区在线视频 | 国产欧美欧美| 国内精品视频在线播放| 亚洲国产日韩在线| 午夜欧美理论片| 亚洲高清中文字幕| 亚洲一级特黄| 欧美国产日韩一区| 国产精品综合视频| 亚洲精品少妇30p| 欧美中文字幕| 亚洲美女中文字幕| 久久久久久夜| 国产精品夜夜嗨| 99视频在线精品国自产拍免费观看| 欧美有码视频| aa国产精品| 欧美成人免费一级人片100| 国产精品天美传媒入口| 一区二区三区产品免费精品久久75| 久久精品国产一区二区电影| 一区二区高清视频| 欧美jizz19hd性欧美| 韩国一区二区在线观看| 亚洲欧美www| 亚洲国产你懂的| 久久一区二区三区国产精品| 国产欧美综合在线| 亚洲人在线视频| 久久天天狠狠| 亚洲一区二区三区中文字幕在线 | 亚洲最新在线视频| 欧美劲爆第一页| 亚洲激情一区二区三区| 免费观看日韩av| 久久疯狂做爰流白浆xx| 国产精品一区二区女厕厕| 亚洲午夜一区二区三区| 日韩小视频在线观看| 欧美日韩免费一区二区三区| 夜夜嗨一区二区| 亚洲精品网址在线观看| 欧美久久电影| 亚洲午夜精品一区二区三区他趣| 亚洲激情电影在线| 欧美精品九九| 亚洲一区二区三区四区五区午夜| 一区二区三区四区国产精品| 国产精品久久波多野结衣| 亚洲一线二线三线久久久| 亚洲欧美日韩视频二区| 国内精品免费在线观看| 欧美a级一区| 狼人天天伊人久久| 日韩亚洲欧美中文三级| 一本色道久久综合狠狠躁篇的优点| 欧美日韩成人综合| 亚洲欧美日本国产有色| 性久久久久久久久久久久| 国产在线精品一区二区夜色| 欧美高清不卡| 欧美日韩一区二区三区四区五区| 在线一区二区三区四区五区| 亚洲欧美不卡| 亚洲欧洲一区| 9国产精品视频| 国产一区日韩二区欧美三区| 亚洲第一在线综合在线| 欧美日韩中文字幕| 久久国产日本精品| 欧美黑人在线播放| 性欧美大战久久久久久久免费观看| 亚洲欧美日韩精品久久亚洲区| 亚洲第一级黄色片| 99re热精品| 亚洲承认在线| 亚洲一级片在线观看| 亚洲第一天堂av| 99精品欧美一区二区三区综合在线| 国产乱码精品一区二区三区忘忧草 | 久久爱www久久做| 亚洲国产精品一区制服丝袜| 一区二区高清| 亚洲第一精品福利| 亚洲精品视频二区| 一区二区三区四区国产| 伊人精品成人久久综合软件| av成人毛片| 亚洲黄色高清| 久久成人亚洲| 亚洲欧美电影在线观看| 欧美激情久久久久| 麻豆国产精品777777在线| 国产精品免费一区二区三区观看| 亚洲国产综合在线| 尤物yw午夜国产精品视频| 亚洲欧美日韩国产成人| 亚洲一线二线三线久久久| 欧美精品二区| 亚洲大胆人体视频| 国精产品99永久一区一区| 中文欧美日韩| 一本色道久久综合狠狠躁篇怎么玩| 久久亚洲美女| 麻豆久久婷婷| 激情综合色综合久久| 欧美在线亚洲在线| 久久精品中文字幕一区二区三区| 国产精品黄色| 亚洲综合不卡| 久久久久国内| 国内成+人亚洲+欧美+综合在线| 亚洲尤物在线视频观看| 亚洲字幕一区二区| 国产伦精品一区| 亚洲女优在线| 久久都是精品| 亚洲精品国产精品乱码不99| 1769国内精品视频在线播放| 久久三级视频| 欧美高清不卡在线| 亚洲美女黄色| 欧美极品一区| 宅男精品导航| 欧美一区二区在线看| 国产日韩欧美精品综合| 亚洲一区欧美激情| 久久久久久久久综合| 亚洲成人中文| 欧美激情亚洲一区| 一区二区三欧美| 久久国产88| 激情五月综合色婷婷一区二区| 久久夜色精品| 亚洲精品欧美日韩专区| 亚洲自拍偷拍福利| 国产一区二区三区丝袜| 久久婷婷国产综合国色天香| 亚洲高清二区| 亚洲欧洲av一区二区| 国产一区二区三区最好精华液| 久久久久一区二区| 亚洲另类一区二区| 久久国产精品毛片| 亚洲精品黄网在线观看| 欧美日韩中文在线| 久久xxxx| 99精品黄色片免费大全| 香蕉久久夜色精品国产| 亚洲国产小视频| 国产精品丝袜白浆摸在线| 久久久综合精品| 日韩视频三区| 亚洲人午夜精品免费| 亚洲黄色成人久久久| 99国内精品久久| 国产一区二区在线观看免费播放| 久久婷婷蜜乳一本欲蜜臀| 野花国产精品入口| 模特精品裸拍一区| 亚洲欧美另类在线观看| 亚洲国产mv| 国产日韩一区在线| 欧美激情综合在线| 久久精品国内一区二区三区| 亚洲国产人成综合网站| 久久米奇亚洲| 亚洲欧美精品伊人久久| 亚洲精品欧洲精品| 在线不卡免费欧美| 国产视频观看一区| 欧美日韩一区三区四区| 老牛影视一区二区三区| 欧美一级免费视频| 亚洲综合国产| 中文亚洲视频在线|