程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> bnu 34895 Elegant String(矩陣快速冪)

bnu 34895 Elegant String(矩陣快速冪)

編輯:C++入門知識

題目鏈接:bnu 34895 Elegant String

題目大意:給定n和k,表示有一個長度為n的序列,序列中的元素由0~k組成,問說有多少個串滿足不包含0~k的全排列。

解題思路:矩陣快速冪,根據dp[i][j]表示說第i為有j個相同,寫出遞推式,根據遞推式求出矩陣。

#include 
#include 

typedef long long ll;
const ll MOD = 20140518;
const int N = 20;

struct mat {
    int r, c;
    ll s[N][N];

    void init (int k, int sign) {

        memset(s, 0, sizeof(s));
        if (sign) {
            r = c = k;
            for (int i = 1; i <= r; i++) {
                for (int j = i; j <= r; j++)
                    s[i][j] = 1;
                if (i == r)
                    continue;
                s[i+1][i] = k+1-i;
            }
        } else {
            r = k;
            c = 1;
            s[1][1] = k+1;
        }
    }

    void put() {
        for (int i = 1; i <= r; i++) {
            for (int j = 1; j <= c; j++)
                printf("%lld ", s[i][j]);
            printf("\n");
        }
    }
};

mat mul(mat a, mat b) {
    mat ans;
    memset(ans.s, 0, sizeof(ans.s));

    for (int i = 1; i <= a.r; i++) {
        for (int j = 1; j <= b.c; j++) {

            for (int x = 1; x <= a.c; x++)
                ans.s[i][j] = (ans.s[i][j] + a.s[i][x] * b.s[x][j])%MOD;
        }
    }
    ans.r = a.r;
    ans.c = b.c;
    return ans;
}

ll n;
int k;

ll solve (ll x) {
    if (x == 1)
        return k+1;
    x--;
    mat ans, cur;
    ans.init(k, 0);
    cur.init(k, 1);

    while (x) {
        if (x&1)
            ans = mul(cur, ans);

        cur = mul(cur, cur);
        x /= 2;
    }

    int sum = 0;
    for (int i = 1; i <= k; i++)
        sum = (sum + ans.s[i][1]) % MOD;
    return sum;
}

int main () {
    int cas;
    scanf("%d", &cas);
    for (int i = 1; i <= cas; i++) {
        scanf("%lld%d", &n, &k);
        printf("Case #%d: %lld\n", i, solve(n));
    }
    return 0;
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved