YOMEDIA
NONE

Cho số tự nhiên n (n ≤ 400). Hãy cho biết có bao nhiêu cách phân tích số n thành tổng của dãy các số nguyên dương, các cách phân tích là hoán vị của nhau chỉ tính là một cách.

Theo dõi Vi phạm
ATNETWORK

Trả lời (1)

  • c++:

    #include <iostream>

    #include <vector>

    using namespace std;

    const int N = (int) 1e5 + 5;

    const int MOD = (int) 1e9;

    int a[N];

    int n;

    int main() {

        cin >> n;

        if (n == 0) {

            cout << 0 << endl;

            return 0;

        }

        vector<int> p;

        for (int i = 1;;) {

            p.push_back(i * (3 * i - 1) / 2);

            if (p.back() >= n) break;

            i = -i;

            if (i > 0) i++;

        }

        a[0] = 1;

        for (int i = 1; i <= n; ++i) {

            int sign = 1, cnt = 0;

            for (int j : p) {

                if (j > i) break;

                a[i] += sign * a[i - j];

                if (a[i] < 0) a[i] += MOD;

                if (a[i] >= MOD) a[i] -= MOD;

                cnt += 1;

                if (cnt == 2) {

                    cnt = 0;

                    sign = -sign;

                }

            }

        }

        cout << a[n] << endl;

        return 0;

    }

      bởi Lan Ha 18/11/2021
    Like (0) Báo cáo sai phạm

Nếu bạn hỏi, bạn chỉ thu về một câu trả lời.
Nhưng khi bạn suy nghĩ trả lời, bạn sẽ thu về gấp bội!

Lưu ý: Các trường hợp cố tình spam câu trả lời hoặc bị báo xấu trên 5 lần sẽ bị khóa tài khoản

Gửi câu trả lời Hủy
 
NONE

Các câu hỏi mới

AANETWORK
 

 

YOMEDIA
ATNETWORK
ON