藍橋杯 基礎練習 階乘計算(C語言)

2021-10-22 10:32:54 字數 968 閱讀 6044

問題描述

輸入乙個正整數n,輸出n!的值。

其中n!=123*…*n。

演算法描述

n!可能很大,而計算機能表示的整數範圍有限,需要使用高精度計算的方法。使用乙個陣列a來表示乙個大整數a,a[0]表示a的個位,a[1]表示a的十位,依次類推。

將a乘以乙個整數k變為將陣列a的每乙個元素都乘以k,請注意處理相應的進製。

首先將a設為1,然後乘2,乘3,當乘到n時,即得到了n!的值。

輸入格式

輸入包含乙個正整數n,n<=1000。

輸出格式

輸出n!的準確值。

樣例輸入

10樣例輸出

3628800

邏輯很簡單,主要就是結果的儲存問題,用乙個整型陣列,每個元素儲存四位數,然後進行運算,注意輸出時,最後乙個元素的值要單獨輸出,避免不足四位的情況。

#include

#define n 10000

intmain()

;//因為結果範圍很大,所以每個陣列元素用來儲存0~9999的數

int k=

0,l=

1,n,i,j;

//k表示進製,l表示陣列長度

scanf

("%d"

,&n)

;for

(i=1

;i<=n;i++)if

(k)}

printf

("%d"

,a[l-1]

);for(i=l-

2;i>=

0;i--

)printf

("%04d"

,a[i]);

return0;

}

藍橋杯C語言基礎練習 階乘計算

問題描述 輸入乙個正整數n,輸出n 的值。其中n 1 2 3 n。演算法描述 n 可能很大,而計算機能表示的整數範圍有限,需要使用高精度計算的方法。使用乙個陣列a來表示乙個大整數a,a 0 表示a的個位,a 1 表示a的十位,依次類推。將a乘以乙個整數k變為將陣列a的每乙個元素都乘以k,請注意處理相...

(藍橋杯)基礎練習 階乘計算

時間限制 1.0s 記憶體限制 512.0mb 問題描述 輸入乙個正整數n,輸出n 的值。其中n 1 2 3 n。演算法描述 n 可能很大,而計算機能表示的整數範圍有限,需要使用高精度計算的方法。使用乙個陣列a來表示乙個大整數a,a 0 表示a的個位,a 1 表示a的十位,依次類推。將a乘以乙個整數...

藍橋杯 基礎練習 階乘計算

時間限制 1.0s 記憶體限制 512.0mb 問題描述 輸入乙個正整數n,輸出n 的值。其中n 1 2 3 n。演算法描述 n 可能很大,而計算機能表示的整數範圍有限,需要使用高精度計算的方法。使用乙個陣列a來表示乙個大整數a,a 0 表示a的個位,a 1 表示a的十位,依次類推。將a乘以乙個整數...