結果

問題 No.300 平方数
ユーザー kongarishisyamokongarishisyamo
提出日時 2016-05-02 04:39:27
言語 C++11
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 625 bytes
コンパイル時間 436 ms
コンパイル使用メモリ 60,512 KB
実行使用メモリ 75,916 KB
最終ジャッジ日時 2024-10-05 02:12:27
合計ジャッジ時間 38,417 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 21 WA * 22
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<iostream>
#include<cmath>
#include<algorithm>

using namespace std;

#define MAX (50000000)
bool hurui[MAX+1];
long long p[3000000];
long long pn=0;
long long N;

int main(){

    for(long long i=0;i<MAX+1;i++) hurui[i]=0;

    for(long long i=2;i<=MAX;i++){
        if(hurui[i]==0){
            for(long long j=i;j<=MAX;j+=i){
                hurui[j]=1;
            }
            p[pn]=i;
            pn++;
        }
    }

	cin>>N;

    long long ans=1;
	for(int i=0;i<pn;i++){
		if(N%p[i]==0){
			long long c=0;
			while(N%p[i]==0){
				N/=p[i];
				c++;
			}
			if(c%2==1) ans*=p[i];
		}
	}

	cout<<ans<<endl;
}
0