unordered_map算法

unordered_map<char, char>s

遍历寻找符合键的元素: s.find(键)!=s.end()

mapunordered_map都是C++ STL提供的关联容器,用于存储键-值对。它们之间的区别主要在于底层实现和搜索/插入/删除操作的性能表现:

  1. map是基于红黑树实现的,它会自动按照键的大小进行排序,因此键值对是有序存储的。在map中查找元素的时间复杂度为O(log n)
  2. unordered_map是基于哈希表实现的,它不保证元素插入的顺序,因为元素是根据哈希值存储的。在unordered_map中查找元素的时间复杂度为O(1),但可能会受到哈希冲突的影响。
  3. 可以直接对map的键值进行遍历操作

409.最长回文串

class Solution {
public:int longestPalindrome(string s) {unordered_map<char,int>count;for(char ch:s){count[ch]++;}int sum=0;bool sign=false;for(int i=0;i<count.size();i++){if(count[i]%2==0){sum+=count[i];}else{sum+=count[i]-1;//减1就能构成回文sign=true;}}return sign?sum+1:sum;//存在奇数次字符多加1}
};

 205.同构字符串

class Solution {
public:bool isIsomorphic(string s, string t) {unordered_map<char, char> s2, t2;for(int i=0;i<s.size();i++){char a=s[i],b=t[i];if((s2.find(a)!=s2.end()&&s2[a]!=b)||(t2.find(b)!=t2.end()&&t2[b]!=a)) //查找到键同时不符合已有映射关系{return false;}s2[a]=b;t2[b]=a;}return true;}
};

 290.单词规律

class Solution {
public:bool wordPattern(string pattern, string s) {using namespace std;// 定义两个映射,一个用于字符到单词,一个用于单词到字符unordered_map<char, string> char_to_word;unordered_map<string, char> word_to_char;vector<string> words;istringstream ss(s); // 使用字符串流来分割字符串string word;// 将字符串 s 按照空格分割成单词while (ss >> word) {words.push_back(word);}// 检查单词的数量是否与模式字符的数量一致if (words.size() != pattern.size()) {return false;}for (int i = 0; i < pattern.size(); i++) {char c = pattern[i];string w = words[i];// 检查从模式字符到单词的映射是否已经存在且一致if ((char_to_word.find(c) != char_to_word.end()&&(char_to_word[c] != w))||((word_to_char.find(w) != word_to_char.end()&&(word_to_char[w] != c)))) {return false;} char_to_word[c] = w;word_to_char[w] = c;}return true;}}
;

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/862555.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python编程题1

1. 输入三角形的底边长和高,计算并输出三角形的面积。 #计算三角形面积s。 import math a=eval(input("底边长:")) h=eval(input("底边对应的高:"))s = a*h/2 print("三角形的面积是{:.2f}".format(s)) 2. 给出三角形的三边,输出三角形的面…

潜水耳机哪个牌子好?榜上有名的四大超赞潜水耳机揭秘

随着探险和运动爱好者对水下世界的探索欲望不断增长&#xff0c;潜水耳机逐渐成为市场上的新宠。它们不仅让我们在深潜时能够与外界保持联系&#xff0c;更为我们提供了一种独特的水下音乐体验。然而&#xff0c;面对众多品牌和型号&#xff0c;选择一款性能优越、安全可靠的潜…

智慧运维系统指导规范

随着信息技术的迅猛发展&#xff0c;智慧运维系统在现代企业中扮演着越来越重要的角色。为了提高运维效率、保障系统稳定运行&#xff0c;并制定一套科学、合理的智慧运维系统指导规范至关重要。本规范旨在为企业提供一套全面、系统的智慧运维管理方法和操作准则&#xff0c;以…

【Android面试八股文】为什么Dialog不能用Application的Context?

文章目录 考察的知识点一、使用Application的Context出现什么状况?二、Window、WM、WMS、Token的概念?三、 Dialog的窗口属于什么类型?四、生命周期管理五、示例五、结论考察的知识点 Window、WindowManager、WindowMangerService之间的关系 享学Dialog使用Activity的Token的…

工作纪实51-手撸AB实验分流策略

前几天写了一篇关于哈希算法的文章&#xff0c;起源就是在构思AB实验平台的时候&#xff0c;用到了哈希&#xff0c;所以对其做了深入的了解 AB实验平台是一般互联网做策略、样式实验会用到的一个系统&#xff0c;一般开启某个实验之后&#xff0c;需要对线上流量进行分流&…

lvs+上一章的内容

书接上回这次加了个keepalived 一、集群与分布式 1.1 集群介绍 **集群&#xff08;Cluster&#xff09;**是将多台计算机组合成一个系统&#xff0c;以解决特定问题的计算机集合。集群系统可以分为以下三种类型&#xff1a; **LB&#xff08;Load Balancing&#xff0c;负载…

创业思维和商业模式的区别,从0到1:构建到突破,专业新零售全案策划

在如今快速变化的市场环境中&#xff0c;创业思维和商业模式的重要性日益凸显。创业思维侧重于创新、冒险和解决问题的能力&#xff0c;而商业模式则关注企业如何创造并获取价值。将这两者有效地融合&#xff0c;不仅可以增强企业的竞争力&#xff0c;还可以帮助企业在市场中取…

希尔排序的实现

引言 排序在我们生活中十分常见&#xff0c;无论是购物软件中的商品推荐还是名次、排名都与排序算法息息相关。希尔排序是排序中较快的一种&#xff0c;而希尔排序实现的基础是插入排序。 排序的实现 插入排序&#xff08;以升序为例&#xff09; 插入排序的原理是从第二个数…

Springboot多模块项目从0构建打包运行

今天复习了一下Springboot的多模块的构建&#xff0c;其实一直以来都对单体项目使用多模块感到不太理解&#xff0c;不知道到底有什么样的优势&#xff0c;目前切身体会到的优势就是确实可以让依赖的划分更加清晰&#xff08;每个模块下的pom文件只引入该模块需要的依赖&#x…

Docker容器 || MySQL容器时间与宿主机同步

网上说的有好几种方式。 本人认为最实用的就是这个&#xff1a; docker exec -it idste_mysql ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime诸如其它的还有&#xff1a; 1、启动的时候直接挂载&#xff0c;这个有效 docker run --name your_container_name -v …

力扣第215题“数组中的第K个最大元素”

在本篇文章中&#xff0c;我们将详细解读力扣第215题“数组中的第K个最大元素”。通过学习本篇文章&#xff0c;读者将掌握如何使用快速选择算法和堆排序来解决这一问题&#xff0c;并了解相关的复杂度分析和模拟面试问答。每种方法都将配以详细的解释&#xff0c;以便于理解。…

wsl ubuntu 安装Anaconda3步骤

如何在Ubuntu上安装Anaconda3呢?本章记录整个安装过程。 1、下载脚本 https://mirrors.bfsu.edu.cn/anaconda/archive/Anaconda3-2023.09-0-Linux-x86_64.sh 下载之后,将脚本上传到Ubuntu里。 2、安装脚本 bash Anaconda3-2021.11-Linux-x86_64.sh根据提示进行安装,提示输…

maven 打包执行配置(对maven引用的包或者丢进去的包都包含在里面)打成jar包

一 、springboot jar包 maven的pom文件 1 在resources下放了一些文件想打进去jar包 2 在lib下放了其他稀奇古怪jar包文件想打进去jar包 编写如下引入jar <build><!-- 打包名称 --><finalName>${project.artifactId}</finalName><resources><…

visual studio 2022配置和使用jsoncpp

下载 jsoncpp下载位置&#xff1a; GitHub - open-source-parsers/jsoncpp: A C library for interacting with JSON. 编译库 1、下载完成之后解压 2、在解压文件的makefiles文件下有个vs71&#xff0c;在vs71中有visual studio项目&#xff0c;不过这里的项目是visual stud…

凸优化相关文章汇总

深度学习/机器学习入门基础数学知识整理&#xff08;三&#xff09;&#xff1a;凸优化&#xff0c;Hessian&#xff0c;牛顿法_深度学习和凸优化-CSDN博客 深度学习/机器学习入门基础数学知识整理&#xff08;四&#xff09;&#xff1a;拟牛顿法、BFGS、L-BFGS、DFP、共轭梯…

NSI66x1B:单通道增强隔离智能栅极驱动器

Single-Channel Isolated Smart Gate Driver 单通道隔离智能门驱动器 参考 Novosense-NSi66x1A_Datasheet_Rev1.x_EN.pdf Product Overview NSI66x1B是一款单通道增强隔离智能栅极驱动器,可在许多应用中驱动igbt和SiC mosfet。它可以输出和吸收10A的峰值电流。系统鲁棒性由…

Leetcode 501:二叉搜索树中的众数

给你一个含重复值的二叉搜索树&#xff08;BST&#xff09;的根节点 root &#xff0c;找出并返回 BST 中的所有 众数&#xff08;即&#xff0c;出现频率最高的元素&#xff09;。 如果树中有不止一个众数&#xff0c;可以按 任意顺序 返回。 假定 BST 满足如下定义&#xf…

如何在服务器中安装anaconda

文章目录 Step1: 下载 Anaconda方法1&#xff1a;下载好sh文件上传到服务器安装方法2&#xff1a;在线下载 Step2: 安装AnacondaStep3: 配置环境变量Step 4: 激活AnacondaStep4: 检验安装是否成功 Step1: 下载 Anaconda 方法1&#xff1a;下载好sh文件上传到服务器安装 在浏览…

Typescript 【实用教程】(2024最新版)含类型声明,类型断言,函数,接口,泛型等

简介 TypeScript 是 JavaScript 的超集&#xff0c;是 JavaScript&#xff08;弱类型语言&#xff09; 的强类型版本。 拥有类型机制文件后缀 .tsTypescript type ES6TypeScript 和 JavaScript 的关系类似 less 和 css 的关系TypeScript对 JavaScript 添加了一些扩展&#x…

入门网络安全工程师要学习哪些内容

大家都知道网络安全行业很火&#xff0c;这个行业因为国家政策趋势正在大力发展&#xff0c;大有可为!但很多人对网络安全工程师还是不了解&#xff0c;不知道网络安全工程师需要学什么?知了堂小编总结出以下要点。 网络安全工程师是一个概称&#xff0c;学习的东西很多&…