• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
            二維樹(shù)狀數(shù)組問(wèn)題。
            以下是我的代碼:
            #include<iostream>
            #include
            <string>
            #include
            <algorithm>
            #include
            <cstdio>
            #include
            <cstring>
            #define lowbit(x) ((x)&(-(x)))
            using namespace std;
            const int kMaxn(1001);

            int bit[kMaxn+7][kMaxn+7],book[kMaxn+7][kMaxn+7];

            void Add(int x,int y,int delta)
            {
                
            for(int i=x;i<=kMaxn;i+=lowbit(i))
                    
            for(int j=y;j<=kMaxn;j+=lowbit(j))
                        bit[i][j]
            +=delta;
            }

            int Sum(int x,int y)
            {
                
            int re(0);
                
            for(int i=x;i>0;i-=lowbit(i))
                    
            for(int j=y;j>0;j-=lowbit(j))
                        re
            +=bit[i][j];
                
            return re;
            }

            int main()
            {
                
            int T;
                scanf(
            "%d",&T);
                
            for(int case_num=1;case_num<=T;case_num++)
                {
                    printf(
            "Case %d:\n",case_num);
                    memset(bit,
            0,sizeof(bit));
                    memset(book,
            0,sizeof(book));

                    
            for(int i=1;i<=kMaxn;i++)
                        
            for(int j=1;j<=kMaxn;j++)
                        {
                            Add(i,j,
            1);
                            book[i][j]
            =1;
                        }

                    
            int Q;
                    scanf(
            "%d",&Q);
                    
            while(Q--)
                    {
                        
            string cmd;
                        cin
            >>cmd;
                        
            if(cmd=="S")
                        {
                            
            int x1,y1,x2,y2;
                            scanf(
            "%d%d%d%d",&x1,&y1,&x2,&y2);
                            x1
            ++;y1++;x2++;y2++;
                            
            if(x1>x2)
                                swap(x1,x2);
                            
            if(y1>y2)
                                swap(y1,y2);
                            printf(
            "%d\n",Sum(x2,y2)-Sum(x1-1,y2)-Sum(x2,y1-1)+Sum(x1-1,y1-1));
                        }
                        
            else if(cmd=="A")
                        {
                            
            int x,y,n1;
                            scanf(
            "%d%d%d",&x,&y,&n1);
                            x
            ++;y++;
                            Add(x,y,n1);
                            book[x][y]
            +=n1;
                        }
                        
            else if(cmd=="D")
                        {
                            
            int x,y,n1;
                            scanf(
            "%d%d%d",&x,&y,&n1);
                            x
            ++;y++;
                            Add(x,y,(book[x][y]
            -n1<0?-book[x][y]:-n1));
                            book[x][y]
            =(book[x][y]-n1<0?0:book[x][y]-n1);
                        }
                        
            else if(cmd=="M")
                        {
                            
            int x1,y1,x2,y2,n1;
                            scanf(
            "%d%d%d%d%d",&x1,&y1,&x2,&y2,&n1);
                            x1
            ++;y1++;x2++;y2++;
                            
            if(book[x1][y1]>n1)
                            {
                                Add(x1,y1,
            -n1);
                                Add(x2,y2,n1);
                                book[x1][y1]
            -=n1;
                                book[x2][y2]
            +=n1;
                            }
                            
            else
                            {
                                Add(x1,y1,
            -book[x1][y1]);
                                Add(x2,y2,book[x1][y1]);
                                book[x2][y2]
            +=book[x1][y1];
                                book[x1][y1]
            =0;
                            }
                        }
                    }
                }

                
            return 0;
            }
            posted on 2011-07-31 10:55 lee1r 閱讀(309) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 題目分類:數(shù)據(jù)結(jié)構(gòu)
            潮喷大喷水系列无码久久精品| 久久精品人成免费| 久久天天躁狠狠躁夜夜不卡| 91精品国产综合久久四虎久久无码一级| 久久99国产精品久久| 日本精品久久久久久久久免费| 青青草原综合久久大伊人| 久久精品中文闷骚内射| 久久无码一区二区三区少妇| 久久精品国产久精国产一老狼| 国内精品伊人久久久久AV影院| 久久97久久97精品免视看 | 91久久精一区二区三区大全| 91精品国产91久久久久久蜜臀| 思思久久99热免费精品6| 2020久久精品国产免费| 免费精品久久天干天干| 久久婷婷久久一区二区三区| 久久婷婷色综合一区二区| 国产99久久久国产精免费| 新狼窝色AV性久久久久久| 亚洲精品tv久久久久| 亚洲国产精品久久久久婷婷老年 | 亚洲精品无码久久久久| 久久亚洲av无码精品浪潮| 久久久精品午夜免费不卡| 久久精品国产亚洲77777| 伊人色综合久久天天网| 久久久久久久综合综合狠狠| 久久er国产精品免费观看2| 国产精品一久久香蕉国产线看观看 | 免费观看成人久久网免费观看| 久久久久久伊人高潮影院| 性做久久久久久久久| 人人狠狠综合久久亚洲| 久久久久国产视频电影| 久久九九免费高清视频| 污污内射久久一区二区欧美日韩| av色综合久久天堂av色综合在| 亚洲精品高清一二区久久| 久久久亚洲精品蜜桃臀|