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

pku2991 Crane 線段樹(shù)的好題

簡(jiǎn)述題意:
一堆豎直依次排列,端點(diǎn)處連接起來(lái)。現(xiàn)在給出這樣一種操作,將第i個(gè)桿子和第i+1個(gè)桿子直接的角度調(diào)整為180+degree,當(dāng)然,i+1個(gè)桿子以后的桿子連著它一起轉(zhuǎn)動(dòng)。求最后一個(gè)桿子的坐標(biāo)
可以這樣設(shè)置線段樹(shù)的域
1 struct
2 {
3     int s,e;
4     double x,y;
5     int turn;
6 }st[N];
turn代表當(dāng)前線段整體旋轉(zhuǎn)過(guò)的角度
維護(hù)策略可以這樣寫:用到了坐標(biāo)的旋轉(zhuǎn)變換矩陣:
|cosx -sinx |
|sinx  cosx|
 1 inline void change(double &x,double &y,double turn)
 2 {
 3     double tx=x,ty=y;
 4     x=cos(turn)*tx-sin(turn)*ty;
 5     y=sin(turn)*tx+cos(turn)*ty;
 6 }
 7 inline void update(int pos,int add)
 8 {
 9     st[pos].turn=(st[pos].turn+add)%360;
10     change(st[pos].x,st[pos].y,degree(add%360));
11 }
其他標(biāo)記下移什么的和普通線段樹(shù)一樣,就不贅述了,貼代碼
 1# include <cstdio>
 2# include <cmath>
 3using namespace std;
 4const int N=50000;
 5const double eps=1e-6;
 6# define degree(a) ((a)/180.0*3.141592653)
 7struct
 8{
 9    int s,e;
10    double x,y;
11    int turn;
12}
st[N];
13int len[N];
14inline void change(double &x,double &y,double turn)
15{
16    double tx=x,ty=y;
17    x=cos(turn)*tx-sin(turn)*ty;
18    y=sin(turn)*tx+cos(turn)*ty;
19}

20inline void update(int pos,int add)
21{
22    st[pos].turn=(st[pos].turn+add)%360;
23    change(st[pos].x,st[pos].y,degree(add%360));
24}

25void init(int s,int e,int pos=1)
26{
27    st[pos].s=s;
28    st[pos].e=e;
29    st[pos].turn=0;
30    if(e==s+1)
31        st[pos].y=len[s],st[pos].x=0;
32    else
33    {
34        init(s,(s+e)>>1,pos<<1);
35        init((s+e)>>1,e,(pos<<1)+1);
36        st[pos].y=st[pos<<1].y+st[(pos<<1)+1].y;
37        st[pos].x=0;
38    }

39}

40int get(int target,int pos=1)
41{
42    if(st[pos].e==st[pos].s+1return st[pos].turn;
43    else if(target<((st[pos].s+st[pos].e)>>1)) return st[pos].turn+get(target,pos<<1);
44    else return st[pos].turn+get(target,(pos<<1)+1);
45}

46
47void insert(int s,int e,int add,int pos=1)
48{
49    if(s==st[pos].s&&e==st[pos].e)
50        update(pos,add);
51    else
52    {
53        if(st[pos].turn)
54        {
55            update(pos<<1,st[pos].turn);
56            update((pos<<1)+1,st[pos].turn);
57            st[pos].turn=0;
58        }

59        if(e<=(st[pos].s+st[pos].e)>>1)
60            insert(s,e,add,pos<<1);
61        else if(s>=(st[pos].s+st[pos].e)>>1)
62            insert(s,e,add,(pos<<1)+1);
63        else
64        {
65            insert(s,(st[pos].s+st[pos].e)>>1,add,pos<<1);
66            insert((st[pos].s+st[pos].e)>>1,e,add,(pos<<1)+1);
67        }

68        st[pos].x=st[pos<<1].x+st[(pos<<1)+1].x;
69        st[pos].y=st[pos<<1].y+st[(pos<<1)+1].y;
70    }

71}

72int main()
73{
74    int n,c,pos,turn,d1,d2;
75    while(scanf("%d%d",&n,&c)!=EOF)
76    {
77        for(int i=1;i<=n;i++)
78            scanf("%d",len+i);
79        init(1,n+1);
80        while(c--)
81        {
82            scanf("%d%d",&pos,&turn);
83            d1=get(pos++);
84            d2=get(pos);
85            insert(pos,n+1,turn-180-d2+d1);
86            printf("%.2f %.2f\n",st[1].x+eps,st[1].y+eps);
87        }

88    }

89    return 0;
90}

posted on 2010-11-03 00:03 yzhw 閱讀(263) 評(píng)論(0)  編輯 收藏 引用 所屬分類: data struct

<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導(dǎo)航

統(tǒng)計(jì)

公告

統(tǒng)計(jì)系統(tǒng)

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評(píng)論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 久久精品国产精品亚洲| 一区二区三区久久网| 欧美自拍偷拍| 国产精品青草久久| 夜夜嗨av一区二区三区网站四季av| 久久综合网hezyo| 午夜老司机精品| 国产精品久久综合| 亚洲欧美日韩在线观看a三区 | 亚洲在线视频| 亚洲久久视频| 欧美视频成人| 亚洲欧美日韩在线| 亚洲欧美日韩中文播放| 国产精品免费视频观看| 久久超碰97中文字幕| 亚洲欧美在线网| 国产亚洲视频在线| 蜜桃av综合| 欧美风情在线观看| 一区二区欧美激情| 亚洲性人人天天夜夜摸| 国产欧美不卡| 久久人人97超碰精品888| 久久久久久久久久久久久久一区| 激情91久久| 亚洲高清视频在线| 午夜性色一区二区三区免费视频| 亚洲大片精品永久免费| 亚洲视频大全| 亚洲女同精品视频| 亚洲三级免费| 欧美日韩在线播放三区| 久久久久久噜噜噜久久久精品| 久久亚洲视频| 亚洲日本欧美| 欧美制服丝袜| 国产欧美一区二区三区在线看蜜臀| 亚洲一本大道在线| 国产模特精品视频久久久久| 欧美高清hd18日本| 国产色产综合色产在线视频| 一区二区三区四区五区在线| 日韩视频国产视频| 黄色精品在线看| 欧美一区二区三区久久精品茉莉花 | 99这里只有精品| 亚洲国产导航| 欧美日韩免费高清一区色橹橹| 欧美一级专区免费大片| 久久男人资源视频| 亚洲一区二区精品在线观看| 久久精品国产亚洲高清剧情介绍| 亚洲久久在线| 久久精品国产亚洲精品| 亚洲午夜一级| 免费成人美女女| 欧美中文字幕在线| 欧美激情视频一区二区三区免费| 欧美在线观看视频一区二区| 欧美激情在线观看| 久久午夜羞羞影院免费观看| 欧美日韩一二三区| 欧美成年网站| 国产午夜精品久久久| 日韩视频二区| 亚洲三级电影全部在线观看高清| 午夜精彩国产免费不卡不顿大片| 亚洲精品久久久久久一区二区| 亚洲欧美视频| 欧美成人一区二区三区在线观看 | 99国产精品自拍| 久久久久久久91| 久久福利一区| 国产精品免费一区二区三区在线观看 | 欧美女人交a| 欧美 日韩 国产 一区| 国产毛片一区| 亚洲免费综合| 亚洲欧美精品在线观看| 欧美日韩免费在线视频| 亚洲国产经典视频| 亚洲国产欧美不卡在线观看| 欧美一区二区三区在线观看视频 | 在线亚洲一区观看| 欧美精品成人91久久久久久久| 美女黄网久久| 伊人一区二区三区久久精品| 久久大综合网| 久久香蕉精品| 在线观看欧美| 久热精品视频| 亚洲第一黄色| 亚洲日本中文字幕区| 欧美高清在线视频观看不卡| 亚洲国产高清视频| 99热免费精品| 亚洲精品人人| 久久av在线| 久久精品一区二区三区不卡| 国产精品乱码人人做人人爱| 亚洲在线中文字幕| 久久久久99| 亚洲国内自拍| 欧美日韩国产成人精品| 亚洲美女色禁图| 亚洲欧美电影院| 国产欧美一区二区视频| 久久国产手机看片| 欧美高清在线观看| av成人天堂| 国产精品日韩一区| 久久国产精品72免费观看| 免费日韩视频| 夜夜夜精品看看| 国产农村妇女毛片精品久久麻豆 | 亚洲国产精品成人| 在线成人亚洲| 欧美刺激性大交免费视频| 亚洲激情啪啪| 香蕉久久夜色精品| 欧美一区二区免费| 欧美国产成人精品| 欧美激情第六页| 午夜亚洲性色视频| 久久精品视频导航| 亚洲韩国日本中文字幕| 欧美日韩精品一区二区| 小黄鸭精品密入口导航| 欧美成人午夜激情在线| 亚洲小视频在线| 伊人久久噜噜噜躁狠狠躁| 欧美成人一区二免费视频软件| 亚洲一区二区不卡免费| 欧美成人在线免费观看| 亚洲欧美中文字幕| 亚洲片在线观看| 国产亚洲欧美一级| 欧美亚州在线观看| 免费久久99精品国产自在现线| 亚洲一区二区三区中文字幕在线 | 欧美成人免费全部观看天天性色| 日韩视频一区二区三区| 久久影院午夜论| 午夜精品视频一区| 亚洲精品在线观| 亚洲成人在线视频网站| 国产日韩在线视频| 国产精品久久久一区二区三区 | 亚洲一区在线免费| 亚洲欧洲综合另类在线| 一区二区三区在线免费观看| 国产精品看片你懂得| 欧美大学生性色视频| 久久国内精品自在自线400部| 一区二区三区在线观看视频| 久久久免费精品| 免费成人高清视频| 亚洲午夜精品一区二区三区他趣| 欧美一区二区三区四区高清 | 欧美在线视频不卡| 日韩视频一区二区三区在线播放免费观看 | 欧美电影在线观看| 久久亚洲综合色| 亚洲欧美影音先锋| 在线性视频日韩欧美| 亚洲三级色网| 亚洲高清网站| 欧美激情小视频| 欧美高清视频| 欧美不卡视频一区| 欧美 日韩 国产在线| 欧美.日韩.国产.一区.二区| 久久免费视频在线| 久久野战av| 免费成人激情视频| 欧美mv日韩mv亚洲| 女同一区二区| 亚洲国产精彩中文乱码av在线播放| 媚黑女一区二区| 欧美va亚洲va香蕉在线| 免费日韩av片| 91久久精品国产91性色tv| 亚洲国产精品久久久久秋霞蜜臀| 欧美激情视频在线免费观看 欧美视频免费一| 久久久久综合网| 美女诱惑一区| 亚洲国产岛国毛片在线| 亚洲国产另类 国产精品国产免费| 激情欧美一区| 亚洲精品1区| 一区二区三区视频在线| 中文日韩电影网站| 性欧美暴力猛交69hd| 久久久久久久999精品视频| 久久在线观看视频| 亚洲国产精品欧美一二99| 亚洲免费成人av电影| 亚洲一区二区免费视频|