結果
| 問題 | 
                            No.36 素数が嫌い!
                             | 
                    
| コンテスト | |
| ユーザー | 
                             Bantako
                         | 
                    
| 提出日時 | 2017-07-13 18:47:40 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                TLE
                                 
                             
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 641 bytes | 
| コンパイル時間 | 247 ms | 
| コンパイル使用メモリ | 23,552 KB | 
| 実行使用メモリ | 47,100 KB | 
| 最終ジャッジ日時 | 2024-10-07 18:26:10 | 
| 合計ジャッジ時間 | 12,590 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge3 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | -- * 4 | 
| other | TLE * 1 -- * 25 | 
コンパイルメッセージ
main.cpp:3:1: warning: ISO C++ forbids declaration of ‘main’ with no type [-Wreturn-type]
    3 | main(){
      | ^~~~
main.cpp: In function ‘int main()’:
main.cpp:16:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   16 |     scanf("%lld",&N);
      |     ~~~~~^~~~~~~~~~~
            
            ソースコード
#include<stdio.h>
int prime[10000001];//素数なら0
main(){
    //素数列を作成
    prime[0] = 1;//0,1は素数ではない
    prime[1] = 1;
    for(int i = 2;i*i <= 10000001;i++){
        if(!prime[i]){
            for(int j = i*2;j <= 10000001;j+=i){
                prime[j] = 1;
            }
        }
    }
    long long N;
    int count = 0;
    scanf("%lld",&N);
    while(N!=1){
        for(int i = 2;i <= 10000000;i++){
            if(prime[i]){continue;}
            if(N%i==0){
                N /= i;
                count++;
                break;
            }
        }
    }
    printf("%s\n",count>=3?"YES":"NO");
}
            
            
            
        
            
Bantako