• <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>

            發現了一道巨神無比的遞推題

            Posted on 2012-03-12 23:30 Mato_No1 閱讀(507) 評論(0)  編輯 收藏 引用 所屬分類: 遞推
            COCI 2011~2012 #2 funkcija
            其思想的巧妙程度以及各種細節的處理難度遠超AHOI2009的cchess(以前本沙茶總以為這種才是最神的遞推題囧……)

            具體的題解以及方法歸納以后再寫,先上代碼:
            #include <iostream>
            #include 
            <stdio.h>
            #include 
            <stdlib.h>
            #include 
            <string.h>
            using namespace std;
            #define re(i, n) for (int i=0; i<n; i++)
            #define re1(i, n) for (int i=1; i<=n; i++)
            #define re2(i, l, r) for (int i=l; i<r; i++)
            #define re3(i, l, r) for (int i=l; i<=r; i++)
            #define rre(i, n) for (int i=n-1; i>=0; i--)
            #define rre1(i, n) for (int i=n; i>0; i--)
            #define rre2(i, r, l) for (int i=r-1; i>=l; i--)
            #define rre3(i, r, l) for (int i=r; i>=l; i--)
            #define ll long long
            const int MAXN = 27, MAXM = 100010, MOD = 1000000007, INF = ~0U >> 2;
            struct edge {
                
            int a, b, pre, next;
            } E[(MAXN 
            << 2+ 1];
            int n, m, A[MAXN][2];
            ll F[MAXN][MAXM], G[MAXN][MAXM], res;
            void init_d()
            {
                re1(i, n) E[i].pre 
            = E[i].next = i; m = n + 1;
            }
            void add_edge(int a, int b)
            {
                E[m].a 
            = a; E[m].b = b; E[m].pre = E[a].pre; E[m].next = a; E[a].pre = m; E[E[m].pre].next = m++;
            }
            void init()
            {
                 scanf(
            "%d"&n);
                 
            char ss0[20], ss1[20];
                 re1(i, n) {
                     scanf(
            "%s %s", ss0, ss1);
                     
            if (ss0[0>= 48 && ss0[0<= 57) A[i][0= atoi(ss0); else A[i][0= 96 - ss0[0];
                     
            if (ss1[0>= 48 && ss1[0<= 57) A[i][1= atoi(ss1); else A[i][1= 96 - ss1[0];
                 }
                 init_d();
                 re1(i, n) {
                     
            if (A[i][0< 0) add_edge(-A[i][0], i);
                     
            if (A[i][1< 0) add_edge(-A[i][1], i);
                 }
            }
            void solve()
            {
                
            int x, y, tmp;
                rre1(i, n) re2(j, 
            1, MAXM) {
                    F[i][j] 
            = 1;
                    
            for (int p=E[i].next; p != i; p=E[p].next) {
                        x 
            = E[p].b;
                        
            if (A[x][0< 0) {
                            
            if (A[x][1>= j) {
                                tmp 
            = G[x][A[x][1]] - G[x][j - 1]; if (tmp < 0) tmp += MOD;
                                F[i][j] 
            = F[i][j] * tmp % MOD; 
                            } 
            else {F[i][j] = 0break;}
                        } 
            else {
                            
            if (A[x][0<= j) {
                                tmp 
            = G[x][j] - G[x][A[x][0- 1]; if (tmp < 0) tmp += MOD;
                                F[i][j] 
            = F[i][j] * tmp % MOD;
                            } 
            else {F[i][j] = 0break;}
                        }
                    }
                    G[i][j] 
            = (G[i][j - 1+ F[i][j]) % MOD;
                }
                res 
            = 1;
                re1(i, n) 
            if (A[i][0> 0 && A[i][1> 0) {
                    tmp 
            = G[i][A[i][1]] - G[i][A[i][0- 1]; if (tmp < 0) tmp += MOD;
                    res 
            = res * tmp % MOD;
                }
            }
            void pri()
            {
                 cout 
            << res << endl;
            }
            int main()
            {
                init();
                solve();
                pri();
                
            return 0;
            }
            色老头网站久久网| 伊人久久大香线蕉AV色婷婷色| 久久免费国产精品一区二区| 精品久久久久成人码免费动漫| 久久精品国产72国产精福利| 久久久久无码国产精品不卡| 久久乐国产综合亚洲精品| 久久婷婷五月综合色奶水99啪| 亚洲精品午夜国产VA久久成人| 久久精品www人人爽人人| 99久久精品国产一区二区三区| 精品久久久久久久国产潘金莲| 亚洲国产另类久久久精品小说 | 久久香蕉国产线看观看99| 久久美女人爽女人爽| 欧美亚洲国产精品久久| 欧美伊香蕉久久综合类网站| 亚洲国产成人久久综合碰| 国产精品久久久天天影视香蕉| 久久亚洲春色中文字幕久久久| 一97日本道伊人久久综合影院| 久久综合精品国产二区无码| 国产999精品久久久久久| A狠狠久久蜜臀婷色中文网| 久久久无码精品亚洲日韩按摩| 久久精品国产精品亚洲下载| 国产三级久久久精品麻豆三级| 久久久久久久久久久精品尤物| 久久免费线看线看| 精品无码久久久久久尤物| 免费精品久久久久久中文字幕| 免费精品国产日韩热久久| 日本久久久精品中文字幕| 日韩人妻无码精品久久免费一 | 久久亚洲AV成人出白浆无码国产| 免费一级做a爰片久久毛片潮| 91精品国产综合久久精品| 国产亚洲精品美女久久久| 久久无码专区国产精品发布| 久久久久人妻精品一区三寸蜜桃| 久久久久亚洲AV成人网人人软件|