#include <stdio.h>
#include <stdlib.h>
int factorial(int n) {
int f;
for(f = 1; n > 0; n--)
f *= n;
return f;
}
int ncr(int n,int r) {
return factorial(n)/(factorial(n-r) * factorial(r));
}
int main(int argc, char* argv[]) {
int n, i, j;
n = atoi(argv[1]);
for(i = 0; i <= n; i++) {
printf("1");
for(j = 1; j <= i; j++)
if(i == j && j > 0) printf(" 1");
else printf(" %d", ncr(i, j));
printf("\n");
}
return 0;
}
如果我使用12以上的數字參數進行測試,我會從第12行(?)得到奇怪的數字。爲什麼會發生這種情況?我應該使用malloc還是數組?有人可以將此代碼更改爲數組或malloc?謝謝。如何將此代碼轉換爲數組或malloc?
因子變得非常快,整數類型很快就不能代表這麼大的數字...... – ForceBru
如果你真的需要處理這麼大的數字,請考慮類似[GNU MP Bignum庫](https: //gmplib.org/)。 –
如果你想解決概率問題,你應該考慮使用'double'。你會失去精確度,但如果你隨着你的增長而增加,你應該沒問題。記住n!/ m!意味着你可以避免在min(m,n)的頂部或底部進行乘法運算,即12!/ 10!顯然是12 * 11 = 132,因爲1 * 2 * 3 * 4 * 5 * 6 * 7 * 8 * 9 * 10被取消。 – Persixty