• <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>
            隨筆-21  評論-10  文章-21  trackbacks-0
            在求每個(gè)置換的不變著色數(shù)時(shí),翻轉(zhuǎn)的置換很容易求,循環(huán)移位的置換暴力找循環(huán)節(jié)(根據(jù)pku 2154跟歐拉數(shù)有關(guān))

             1 #include<iostream>
             2 #include<stdio.h>
             3 using namespace std;
             4 typedef long long ll;
             5 ll ans[24], three[24];
             6 
             7 int c[24];
             8 bool visit[24];
             9 
            10 int xunhuan(int c[], int n) {
            11     int i, j, cnt = 0;
            12     for (i = 0; i < n; i++)
            13         visit[i] = false;
            14     for (i = 0; i < n; i++)
            15         if (!visit[i]) {
            16             cnt++;
            17             j = i;
            18             while (!visit[j]) {
            19                 visit[j] = true;
            20                 j = c[j];
            21             }
            22         }
            23     return cnt;
            24 }
            25 
            26 ll solve_odd(int n) {
            27     int i, j;
            28     ll ans = 0;
            29     for(i = 0; i < n; i++)
            30     {
            31         for(j = 0; j < n; j++)
            32             c[j] = (j+i)%n;
            33         ans += three[ xunhuan(c, n) ];
            34     }
            35     ans += n * three[n/2+1];
            36     return ans / ( 2 * n );
            37 }
            38 
            39 ll solve_even(int n) {
            40     int i, j;
            41     ll ans = 0;
            42     for(i = 0; i < n; i++)
            43     {
            44         for(j = 0; j < n; j++)
            45             c[j] = (j+i)%n;
            46         ans += three[ xunhuan(c, n) ];
            47     }
            48     ans += n / 2 * ( three[n/2+ three[n/2+1] );
            49     return ans / ( 2 * n );
            50 }
            51 
            52 void init() {
            53     int i;
            54     three[0= 1;
            55     for (i = 1; i < 24; i++)
            56         three[i] = three[i - 1]*3;
            57 
            58     for (i = 1; i < 24; i += 2) {
            59         ans[i] = solve_odd(i);
            60         //printf("%lld\n",ans[i]);
            61     }
            62     for (i = 2; i < 24; i += 2) {
            63         ans[i] = solve_even(i);
            64         //printf("%lld\n",ans[i]);
            65     }
            66 }
            67 
            68 int main() {
            69     int i;
            70 //    while(scanf("%d",&i)!=EOF)
            71 //        solve_odd(i);
            72     init();
            73     while (scanf("%d"&i) != EOF) {
            74         if (i == -1)break;
            75         printf("%lld\n", ans[i]);
            76     }
            77 }


            posted on 2009-09-02 16:10 wangzhihao 閱讀(437) 評論(0)  編輯 收藏 引用 所屬分類: math
            久久嫩草影院免费看夜色| 久久国产免费观看精品3| 国内精品久久人妻互换| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 日本WV一本一道久久香蕉| 久久精品国产99久久久香蕉| 青青草原综合久久大伊人精品| 嫩草伊人久久精品少妇AV| 久久夜色精品国产噜噜噜亚洲AV| 亚洲国产成人久久综合碰| 伊人久久大香线蕉精品不卡 | 日韩精品久久久久久| 国产精品久久久久久久久鸭 | 中文字幕精品久久久久人妻| 亚洲一区精品伊人久久伊人| 久久天天躁夜夜躁狠狠| 亚洲精品乱码久久久久久蜜桃图片 | 国内精品久久久久伊人av| 99国产欧美精品久久久蜜芽| 国产亚洲欧美成人久久片| 日本久久久久久中文字幕| 日韩美女18网站久久精品| 久久无码中文字幕东京热| 99久久人妻无码精品系列蜜桃| 成人a毛片久久免费播放| 日本欧美国产精品第一页久久| 久久精品国产2020| 久久国产高清字幕中文| 一个色综合久久| 国产精品久久影院| 久久久久无码精品| 久久亚洲精品国产精品| 国产精品女同一区二区久久| 欧美日韩久久中文字幕| 蜜桃麻豆www久久| 亚洲精品无码久久久久久| 99久久亚洲综合精品网站| 伊人久久无码中文字幕| 精品国产青草久久久久福利| 麻豆精品久久久久久久99蜜桃| 日韩亚洲欧美久久久www综合网 |