素数判定

#include<iostream>
#include<math>
using namespace std;
int main( int argc, char** argv ){
	int lim = 0;
	int i;
	bool isPrime = true;
	sscanf( argv[ 1 ], "%d", &lim );
	for( i = 2; i < ( int )( sqrt( lim ) + 1.0 ); i ++ ){
		if(( lim % i ) == 0 ){
			isPrime = false;
			break;
		}
	}
	if( isPrime ){
		printf( "%dは素数\n", lim );
	}else{
		printf( "%dは非素数\n", lim );
	}
	return 0;
}

おまけで素数列挙

#include<iostream>
#include<math>
using namespace std;
int main( int argc, char** argv ){
	int lim = 0;
	int i, j;
	bool isPrime;
	sscanf( argv[ 1 ], "%d", &lim );
	if( lim == 0 ){
		return -1;
	}
	printf( "%d ", 2 );
	for( i = 3; i < lim; i ++ ){
		isPrime = true;
		for( j = 2; j < ( int )( sqrt( i ) + 1.0 ); j ++ ){
			if(( i % j ) == 0 ){
				isPrime = false;
				break;
			}
		}
		if( isPrime ){
			printf( "%d ", i );
		}
	}
	return 0;
}

トップ   編集 凍結 差分 履歴 添付 複製 名前変更 リロード   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS
Last-modified: 2023-02-23 (木) 23:33:34