找到了Stroustrups初学者书Ch4Ex15的答案,问题是找到前n个素数:
#include "std_lib_facilities.h"
bool prime (vector<int> table, int number) {
for (int i = 0; i < table.size(); ++i)
if (number%table[i] == 0) return false;
return true;
}
int main () {
int count, next;
cout << "Input the number of primes\n";
cin >> count;
vector<int> table;
next = 2;
while (table.size() < count) {
if (prime(table,next)) table.push_back(next);
++next;
}
for (int n = 0; n < table.size(); ++n)
cout << table[n] << " ";
cout << endl;
// keep_window_open();
return 0;
}
我很难理解的两件事:
bool prime (vector<int> table, int number)
和
if (prime(table,next))
谢谢, 肖恩
答案 0 :(得分:-1)
您要问的事情是C和C ++语言的基础。通读任何好的C ++教科书的前2-3章,都会为您解答这些问题。
示例代码定义 2个功能:prime
和main
。
main
之外的代码是prime
函数的定义。它是在main
函数中定义的(在此处创建)供以后调用。prime
的定义,第二件事是对该函数的调用。