求素数,用vector存储的实现方法

PS:如有不足之处,还望指正!
复制代码 代码如下:

// tentotwo.cpp : 定义控制台应用程序的入口点。
#include "stdafx.h"
#include
#include
using namespace std;
void GetPrimer(int n, vector& vet)
{
 for (int i = 2; i <= n; i++)
 {
  vet.push_back(i);
 }
 vector::iterator ite = vet.begin();
 while (ite != vet.end())
 {
  vector::iterator tmpite = ite + 1;
  while (tmpite != vet.end())
  {
   if ((*tmpite)%(*ite) == 0)
   {
    tmpite = vet.erase(tmpite);
   }
   else
   {
    tmpite ++;
   }
  }  
  ite ++;
 } 
}
int _tmain(int argc, _TCHAR* argv[])
{
 vector vet;
 GetPrimer(100, vet);
 vector::iterator ite = vet.begin();
 while (ite != vet.end())
 {
  cout << *ite << " ";
  ite ++;
 }
 cout << endl;
 return 0;
}

你可能感兴趣的:(求素数,用vector存储的实现方法)