結果

問題 No.713 素数の和
ユーザー youthfuldays072youthfuldays072
提出日時 2018-08-08 11:52:36
言語 C++11
(gcc 11.4.0)
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 805 bytes
コンパイル時間 539 ms
コンパイル使用メモリ 66,888 KB
最終ジャッジ日時 2024-04-27 02:35:48
合計ジャッジ時間 833 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
main.cpp: In function ‘std::vector<int> Eratosthenes(int)’:
main.cpp:25:19: error: ‘sqrt’ was not declared in this scope
   25 |         rep(i, 2, sqrt(n)) {
      |                   ^~~~
main.cpp:15:34: note: in definition of macro ‘rep’
   15 | #define rep(i,a,b) for(int i=a;i<b;i++)
      |                                  ^

ソースコード

diff #


#include<iostream>
#include<string>
#include<algorithm>
#include<functional>
#include<vector>
#include<set>
#include<queue>
#include<list>
#include<stdio.h>
#include<stdlib.h>
#include<map>

#define rep(i,a,b) for(int i=a;i<b;i++)
#define rrep(i,a,b) for(int i=a;i>=b;i--)
#define fore(i,a) for(auto &i:a)
#define all(x) (x).begin(),(x).end()

using namespace std;

vector<int> Eratosthenes(int n) {
	vector<int> a(n, 1);

	rep(i, 2, sqrt(n)) {
		if (a[i]) {
			for (int j = 0; i*(j + 2)< n; j++) {
				a[i*(j + 2)] = 0;
			}

		}
	}

	vector<int> primes;

	for (int i = 2; i < n; i++) {
		if (a[i]) {
			primes.push_back(i);
		}
	}
	
	return primes;
}

int main() {

	int n;
	cin >> n;

	auto ans = Eratosthenes(n+1);

	int sum = 0;
	fore(i, ans) {
		sum += i;
	}

	cout << sum << endl;

	return 0;
}

0