In STL , there are many method can traverse the vector object , but the most efficency one ,I think , it's 'for_each' function. And it can be used very near the real life language , what you need do is only to define a function express how you want to act while it's traversing.
E.G
/********************************************************************
created: 2007/04/19
created: 19:4:2007 2:04
filename: C:\testvc6\TestStll\TestStll.cpp
file path: C:\testvc6\TestStll
file base: TestStll
file ext: cpp
author: Chang xinglong(King.C)
purpose: How to traverse a Vector ?
*********************************************************************/
You can define a travers Function which simply couput the node data , it was defined like this :
void Traverse(int t)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
cout<<t<<endl;
};
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
Then Create a integer vector , and use the for each to travers it ,here the code goes like this:
vector <int> colt;
for (int i=0; i<=10;i++)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
{
colt.push_back(i);
}
for_each(colt.begin(),colt.end(),Traverse);
cout<<endl;
Very easy and effiency , try to use it in the program instead of the following code:
for (int i=0;i<max;i++)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
int v =(int) aVector[i];
traverse(v);
}