国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

完全平方數(shù)

2019-11-14 12:42:12
字體:
供稿:網(wǎng)友

題目描述:

一個數(shù)如果是另一個整數(shù)的完全平方,那么我們就稱這個數(shù)為完全平方數(shù)(Pefect Sqaure),也稱平方數(shù)。小A認(rèn)為所有的平方數(shù)都是很perfect的~于是他給了小B一個任務(wù):用任意個不大于n的不同的正整數(shù)相乘得到完全平方數(shù),并且小A希望這個平方數(shù)越大越好。請你幫助小B告訴小A滿足題意的最大的完全平方數(shù)。

輸入格式:

輸入文件名為number.in輸入僅 1行,一個數(shù)n。

輸出格式:

輸出文件名為number.out輸出僅1行,一個數(shù)表示答案。由于答案可以很大,所以請輸出答案對100000007

樣例輸入:

樣例17樣例29

樣例輸出:

樣例1144樣例25184

數(shù)據(jù)范圍:

對于20%的數(shù)據(jù),0<n≤100;對于50%的數(shù)據(jù),0<n≤5,000;對于70%的數(shù)據(jù),0<n≤100,000;對于100%的數(shù)據(jù),0<n≤5,000,000。

時間限制:

1S

空間限制:

128M

提示:

【輸入輸出樣例解釋1】144=2×3×4×6,是12的完全平方。【輸入輸出樣例解釋2】5184=3×4×6×8×9,是72的完全平方。

 

 

 

 

 

 

 

 

 

先上代碼。

#include<bits/stdc++.h>using namespace std;const int mod=100000007;int a[5000001],n,s;long long PRime[50000001],m;bool pg[5000001];void init(){cin>>n;}void prepare(){pg[1]=1;pg[2]=0;for(int i=2;i<=n/2+1;i++){if(!pg[i]){prime[++s]=1;a[s]=0;for(int j=1;j*i<=n;j++){int ll=j;a[s]++;while (ll%i==0){a[s]++;ll/=i;}pg[j*i]=1;}if (a[s]%2==1) a[s]--;// cout<<i<<" "<<a[s]<<"/n";for(int j=1;j<=a[s];j++){prime[s]*=i;if(prime[s]>20000) prime[s]=prime[s]%mod;}}}}void doit(){m=1;for(int i=1;i<=s;i++){m*=prime[i];if(m>10000){m=m%mod;}}}void print(){cout<<m;}int main(){init();prepare();doit();print();}

解析:本題比較好想,方法:將n!分解質(zhì)因數(shù)后將奇數(shù)的質(zhì)因子個數(shù)減一,再將所有質(zhì)因子乘起來取余即可。

優(yōu)化:

1、篩素數(shù)時,搜到一半就可以停了,后面的質(zhì)數(shù)不可能因子數(shù)超過一個。

2、快速冪(這里沒加),多乘幾次再取模。

證明:

      奇?zhèn)€數(shù)的的質(zhì)因數(shù)一定可去,且留著也沒用。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 收藏| 容城县| 江西省| 鄂托克旗| 黎城县| 若羌县| 汤原县| 西安市| 民勤县| 商河县| 来安县| 嘉义县| 安义县| 炉霍县| 桦南县| 阿鲁科尔沁旗| 高尔夫| 静海县| 盐亭县| 荥经县| 华蓥市| 南川市| 渑池县| 黔西县| 安达市| 汉阴县| 遂昌县| 洮南市| 贵阳市| 昌平区| 长兴县| 云龙县| 屏南县| 攀枝花市| 融水| 图们市| 青冈县| 宜兰市| 新营市| 竹溪县| 卢湾区|