服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言 map函数的基础用法详解

C语言 map函数的基础用法详解

2022-08-05 11:40水深00安东尼 C/C++

这篇文章主要为大家介绍了C语言 map函数的基础用法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

map

有N个学生的姓名name和学号ID,要求给你一个学生的name求查找他的ID。

简单做法是定义 string name [ N ] int ID[ N ] 存储信息,然后在name [ ] 中查找这个学生,找到后输出他的ID。但是这样的缺点是需要查找所有的name [ N ],时间复杂度是O( N ),效率低下。

利用 STL 中 map容器 可以快速实现查找,复杂度是O( log 2 N )。

map是关联容器,它实现从键(key)到值(value)得的映射。map效率高的原因是它利用平衡二叉搜索树来存储和访问。

一般的数组也是用映射方法实现的。

int a[ 100 ],是定义了从int型到int型的映射,比如 a[ 4 ]=36就分别是将 4 映射到 36

double b[ 100 ],是定义了从int型到int型的映射,比如 b[ 5 ]=0.009 就分别是将 5 映射到 0.009

map具体操作

( 1 ) 定义:例如 map<string , int> 代表从字符串映射到数字,还含有多种映射。(注意,字符串到整型的映射,必须是string而不是char

( 2 ) 赋值:例如 a[ “TOM” ]=15,这里把 “TOM” 当成普通数组下标来使用。

( 3 ) 查找:可以直接使用 a[ “TOM” ]表示,不必要搜索所有的值。

注意map是C++的函数,必须使用C++头文件。例题 POJ 2153

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#include<iostream>
#include<cstring>
#include<map>//map函数头文件
using namespace std;
map<string ,int> x;//定义从string映射到int
char s[10010][50];
char b[50],c[50]="Li Ming";
int main()
{
    int m,n,i,j,num,sum,sort;
    scanf("%d",&n);
    getchar();
    for(i=1;i<=n;i++)
    {
        gets(s[i]);
        x[s[i]]=0;//将s[i]当做是普通数组下标使用
    }
    scanf("%d",&m);
    while(m--)
    {
        sort=1;
        for(i=1;i<=n;i++)
        {
            scanf("%d",&num);
            getchar();
            gets(s[j]);
            x[s[j]]+=num;//成绩相加
        }
        for(i=1;i<=n;i++)
        if(strcmp(c,s[i])==0) sum=x[s[i]];//刷新"Li Ming"的分数
        for(i=1;i<=n;i++)
        if(x[s[i]]>sum) sort++;//求"Li Ming"的名次
        printf("%d\n",sort);
    }
    return 0;
}

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注服务器之家的更多内容!

原文链接:https://blog.csdn.net/weixin_54793960/article/details/122280831

延伸 · 阅读

精彩推荐
  • C/C++C++算法之海量数据处理方法的总结分析

    C++算法之海量数据处理方法的总结分析

    本篇文章是对海量数据处理方法进行了详细的总结与分析,需要的朋友参考下...

    C++教程网2932020-12-12
  • C/C++C++设计模式之中介者模式

    C++设计模式之中介者模式

    这篇文章主要介绍了C++设计模式之中介者模式,本文讲解了什么是中介者模式、中介者模式的使用场合、中介者模式的优缺点等内容,需要的朋友可以参考下...

    果冻想8852021-02-05
  • C/C++约瑟夫环问题(数组法)c语言实现

    约瑟夫环问题(数组法)c语言实现

    这篇文章主要介绍了约瑟夫环问题(数组法)c语言实现,有需要的朋友可以参考一下...

    C语言教程网12272021-01-12
  • C/C++C++实现LeetCode(132.拆分回文串之二)

    C++实现LeetCode(132.拆分回文串之二)

    这篇文章主要介绍了C++实现LeetCode(132.拆分回文串之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下...

    Grandyang3992021-11-23
  • C/C++C语言实现简易版扫雷小游戏

    C语言实现简易版扫雷小游戏

    这篇文章主要为大家详细介绍了C语言实现简易版扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    浪漫不死4452021-09-15
  • C/C++详解C++ 拷贝构造函数和赋值运算符

    详解C++ 拷贝构造函数和赋值运算符

    本文主要介绍了拷贝构造函数和赋值运算符的区别,以及在什么时候调用拷贝构造函数、什么情况下调用赋值运算符。最后,简单的分析了下深拷贝和浅拷...

    Brook_icv9992021-04-21
  • C/C++C语言中单链表的基本操作指南(增删改查)

    C语言中单链表的基本操作指南(增删改查)

    链表跟数组不同的是非连续存储结构,也就是说实现链表需要一个指针,每用完一个节点指针指向下一个节点,直至表尾,下面这篇文章主要给大家介绍了关于...

    若爱我菲、3572021-12-30
  • C/C++C语言数字图像处理之图像缩放

    C语言数字图像处理之图像缩放

    这篇文章主要为大家详细介绍了C语言数字图像处理之图像缩放,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    ZhaoDongyu_AK473682022-02-15