日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

九度OJ 1076:N的阶乘 (数字特性、大数运算)

發布時間:2023/12/18 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 九度OJ 1076:N的阶乘 (数字特性、大数运算) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

時間限制:3 秒

內存限制:128 兆

特殊判題:否

提交:6384

解決:2238

題目描述:

?輸入一個正整數N,輸出N的階乘。

輸入:

正整數N(0<=N<=1000)

輸出:

?輸入可能包括多組數據,對于每一組輸入數據,輸出N的階乘

樣例輸入:
4 5 15
樣例輸出:
24 120 1307674368000
來源:
2006年清華大學計算機研究生機試真題

思路:

數很大,long long都表示不了,實際考察的是大整數乘法。

我寫的代碼可以實現,但應該有比較大的優化余地。


代碼:

#include <stdio.h>int main(void) {int n;int a[3001];int i, j;while (scanf("%d", &n) != EOF){for (j=0; j<3001; j++)a[j] = 0;a[0] = 1;for (i=1; i<=n; i++){for (j=0; j<3*i; j++)a[j] *= i;for (j=0; j<3*i; j++){if (a[j] >= 10){a[j+1] += a[j]/10;a[j] %= 10;}}}for (i=3*n; i>=0; i--){if (a[i] != 0)break;}//printf("%d\n\n", i);for (j=i; j>=0; j--)printf("%d", a[j]);printf("\n");}return 0; } /**************************************************************Problem: 1076User: liangrx06Language: CResult: AcceptedTime:2390 msMemory:912 kb ****************************************************************/

轉載于:https://www.cnblogs.com/liangrx06/p/5083956.html

總結

以上是生活随笔為你收集整理的九度OJ 1076:N的阶乘 (数字特性、大数运算)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。