广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言中map函数的基础用法是什么
  • 545
分享到

C语言中map函数的基础用法是什么

2023-06-22 07:06:04 545人浏览 薄情痞子
摘要

C语言中map函数的基础用法是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。map有N个学生的姓名name和学号ID,要求给你一个学生的name求查找他的I

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

#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;}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网其他教程频道,感谢您对编程网的支持。

--结束END--

本文标题: C语言中map函数的基础用法是什么

本文链接: https://www.lsjlt.com/news/303389.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言中map函数的基础用法是什么
    C语言中map函数的基础用法是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。map有N个学生的姓名name和学号ID,要求给你一个学生的name求查找他的I...
    99+
    2023-06-22
  • C语言map函数的基础用法详解
    目录mapmap具体操作总结map 有N个学生的姓名name和学号ID,要求给你一个学生的name求查找他的ID。 简单做法是定义 string name [ N ] 和 int I...
    99+
    2022-11-12
  • C语言中power函数的用法是什么
    在C语言中,power函数用于计算一个数的幂。函数原型为:```cdouble pow(double x, double y);``...
    99+
    2023-10-12
    C语言
  • c语言中fopen函数的用法是什么
    fopen函数是C语言中用于打开文件的函数。其使用方法如下:```cFILE *fopen(const char *filename...
    99+
    2023-09-12
    C语言
  • c语言中prime函数的用法是什么
    在C语言中,prime函数的用法是判断一个数是否为素数(质数)。素数是指除了1和它本身之外没有其他因子的正整数。例如,2、3、5、7...
    99+
    2023-09-27
    c语言
  • C语言中strtol函数的用法是什么
    这篇文章主要讲解了“C语言中strtol函数的用法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言中strtol函数的用法是什么”吧!strtol 函数用法strtol是一个C语言...
    99+
    2023-06-20
  • C语言基础函数用法示例详细解析
    目录函数函数定义函数一般格式C语言函数分类库函数库函数的分类库函数的学习自定义函数函数的参数实际参数形式参数函数的调用传值调用传址调用无参函数调用函数的声明和定义函数的声明函数的定义...
    99+
    2022-11-12
  • c语言realloc函数的用法是什么
    realloc函数是用于重新分配内存块的大小的函数。它可以用于扩大或缩小已经分配的内存块的大小。realloc函数的用法如下:voi...
    99+
    2023-09-14
    c语言
  • c语言strcpy函数的用法是什么
    strcpy函数是C语言中的一个字符串处理函数,其原型如下:```cchar* strcpy(char* dest, const c...
    99+
    2023-09-14
    c语言
  • c语言strlen函数的用法是什么
    strlen函数用来计算字符串的长度,不包括字符串末尾的空字符('\0')。其用法如下:```c#include size_t st...
    99+
    2023-09-14
    c语言
  • c语言ioctl函数的用法是什么
    在C语言中,ioctl函数是用来控制设备的系统调用函数。它的原型如下:cint ioctl(int fd, unsigned lon...
    99+
    2023-10-18
    c语言
  • c语言abs函数的用法是什么
    c语言中的abs函数用于返回一个整数的绝对值。其语法如下:int abs(int n);其中,n为要求绝对值的整数。abs函数的返回...
    99+
    2023-10-21
    c语言
  • c语言isalpha函数的用法是什么
    isalpha函数是C语言中的一个字符判断函数,用于判断给定的字符是否为字母。其函数原型为: int isalpha(int c);...
    99+
    2023-10-26
    c语言
  • c语言readline函数的用法是什么
    在C语言中,`readline()`函数用于从文件中读取一行内容,并将其存储到字符串中。 `readline()`函数的声明如下: ...
    99+
    2023-10-26
    c语言
  • C语言fwrite函数的用法是什么
    fwrite函数是C语言中的一个文件操作函数,用于将数据块写入文件中。其基本用法如下:```csize_t fwrite(const...
    99+
    2023-09-12
    C语言
  • c语言calloc函数的用法是什么
    calloc函数是C语言中的一个动态内存分配函数,用来分配一片连续的内存空间,并将其初始化为0。其函数原型如下所示: void *c...
    99+
    2023-10-26
    c语言
  • c语言feof函数的用法是什么
    feof函数是C语言标准库中的一个函数,用于判断文件流是否已经到达文件结尾。它的用法如下: #include int feof(...
    99+
    2023-10-23
    c语言
  • c语言attribute函数的用法是什么
    在C语言中,attribute函数用于指定函数属性。它可以用于函数声明或定义中,以指定一些特定的行为或属性。attribute函数通...
    99+
    2023-10-24
    c语言
  • c语言locate函数的用法是什么
    C语言中的`locate`函数并不存在。也许你指的是`strstr`函数,它用于在一个字符串中查找另一个字符串的位置。以下是`str...
    99+
    2023-10-25
    c语言
  • c语言load函数的用法是什么
    在C语言中,load函数通常是指用于从文件中加载数据到内存中的函数。load函数的具体用法会根据不同的上下文和具体需求而有所区别,下...
    99+
    2023-10-25
    c语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作