C++的STL之map自动排序特性

#include <iostream>
#include <map>
using namespace std;

int main()
{
方法一: map
<int,int> m; srand((unsigned)time(NULL)); for (int i =0; i< 100; i++) { int key = rand()%100+1;//1~100的随机数 int value = rand()%2;//0或1随机数 printf("第%d次插入前:key=%d, value=%d ",i+1,key,value); m.insert(pair<int,int>(key,value)); } printf(" "); map<int,int>::iterator iter; for (iter = m.begin(); iter != m.end(); iter++) { printf("key:%d, value:%d ",iter->first,iter->second); } printf(" "); return 0; }

C++的STL之map自动排序特性

自动排序:

C++的STL之map自动排序特性

 方法二(26个英文字母):

#include <iostream>
#include <map>
using namespace std;

int main()
{
    map<int,int> mc;
    srand((unsigned)time(NULL));

    for (char c='z'; c >= 'a'; c--)
    {
        int num = rand()%2;
        printf("%c,  %d
",c,num);
        mc.insert(pair<char,int>(c,num));
    }

    printf("
");


    map<char,int>::iterator iter;

    for (iter = mc.begin(); iter!=mc.end(); iter++)
    {
        printf("key= %c, value=%d
",iter->first,iter->second);
    }

    printf("
");
    return 0;
}

C++的STL之map自动排序特性

遍历map:

C++的STL之map自动排序特性