切換
舊版
前往
大廳
主題

ZeroJudge - e293: 花開花落,雨初臨 解題心得

Not In My Back Yard | 2019-07-18 23:30:06 | 巴幣 0 | 人氣 246

題目連結:


題目大意:
給定一正整數 n (n ≦ 5, 000),代表接下來 n 列,每列有一正整數(位數長 ≦ 5, 000)。求給定的正整數有無 100 以內的質因數。有的話,由小到大輸出那些質因數;反之,如果不存在任何 100 以內的質因數,輸出「Terrible Silence...」。

時限:0.4 s 。



範例輸入:
3
1
3
15


範例輸出:
Terrible Silence...
3
3 5


解題思維:
根據餘數的性質(詳情看這篇文章),我們可以一位數一位數地慢慢地取餘數,看最後的餘數是否為 0 ,即可判斷此數是否為某數的倍數。

但是因為 < 100 的質數有 25 個,所以最多可能會超過 5000 × 5000 × 25 個運算。因此直接做會超過時限。(計算是內建大數運算的語言直接取模也會超時)

而我們可以先把所有質數乘起來成為一個數字,然後用這個數字作為模數去對給定的數字取模。取完模之後再用這個餘數用上面的演算法去各自判斷各自是否為這些質數的倍數。

因為(x mod 6) mod 2=x mod 2、(x mod 6) mod 3=x mod 3,其他情況也是類似。因此先對 100 以內的質數之乘積(2 × 3 × 5 × …… × 97)取模可以將數字縮短到 37 位數以內。

因此,此時再對此餘數取模即可推得本來的餘數而不需大量的運算。

因此,有內建大數運算的語言(像 Python 、 Java 等)會比較輕易實行上面的方法;而 C++ 等的語言,不是要自己寫大數運算,就是要把那個乘積拆成好幾個部分使得可以用 long long 型態裝下等等。

此次分享到此為止,如有任何更加簡潔的想法或是有說明不清楚之地方,也煩請各位大大撥冗討論。

創作回應

相關創作

更多創作