replace,push_back,vector:约瑟夫环精简迷你版

// 

#include <iostream>

#include <vector>

#include <algorithm>

 

using namespace std;

 

 

 

int main (int, char *[])

{

const int sizeLegth = 10000;

 

 

vector<int> num1000;

vector<int> num;

int count = 0;

for(int size = 0;size < sizeLegth; ++size)

num1000.push_back(size);

 

vector<int>::iterator numIt = num1000.begin()-1;

for(numIt = num1000.begin()+2;numIt <= num1000.end()-1;numIt+=3)

 

{

replace(num1000.begin(), num1000.end(), *numIt, 0);//要删除的修改为0

//cout << *numIt << " ";//2 5 8 11 14 17 20 23 26 .....

}

 

//将值不为0的填入另一容器。

for(numIt=num1000.begin();numIt != num1000.end();++numIt)

{

if(0 == *numIt)continue;

num.push_back(*numIt);

++count;

 

}

 

cout << "reseult is: " << count <<endl; // 666

return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值