字符串去重整理 哈希映射解题

news2024/11/17 5:30:00

目录

给你一个字符串数组,删除他们之间相同的元素,(保留一个重复值)

【方法一】使用迭代器进行区间删除

 【方法二】原地删除

 【方法三】使用计数跳过

 1002. 查找共用字符

【解法一】我的第一个理解题意出错的解法

【解法二】初步使用哈希思想

【解法三】使用Hash


给你一个字符串数组,删除他们之间相同的元素,(保留一个重复值)

首先都进行sort排序(字符串也能进行排序!!!)

排序规则与strcmp比较函数类似

【方法一】使用迭代器进行区间删除

iterator erase (iterator first, iterator last);

这里可以进行控制是否要保留这一个重复的元素,分辨出题目要求是否保留重复元素

下方代码就是进行对第一个重复值的保留

 

如果不想对第一个进行保留,即题目要求删除所以重复出现元素,那么在erase操作将i+1中+1去掉即可

 

vector<string> delete_repeat(vector<string> v)
{
    sort(v.begin(), v.end());
    for (int i  = 0; i  < v.size(); ++i)
    {
        string temp  = v[i];
        int j  = i;
        while (j  < v.size() && temp  == v[j])
        {
            j++;
        }
        v.erase(v.begin() + i + 1, v.begin() + j);
    }
    return v;
}

 【方法二】原地删除

注意erase删除后下标i仍然不动,所以不需要对i下标进行++操作

    vector<string> delete_repeat(vector<string> v)
    {
        sort(v.begin(), v.end());
        for(size_t i = 0; i < v.size();)
        {
            auto temp = v[i];
            if(v[i+1] == temp)
            {
                while(i<v.size() && v[i]==temp)
                {
                    auto it = v.begin()+i;
                    v.erase(it);
                }
            }
            else
                ++i;
        }
        return v;
    }

 【方法三】使用计数跳过

        string compressString(string s) {
        string res;
        for(size_t i = 0; i < s.size();)
        {
            res+=s[i];
            int count = 0;
            if(i!=s.size()-1 && s[i+1]==s[i])
            {
                char ch = s[i];
                int j = i;
                while(ch == s[j])
                {
                    count++;
                    j++;
                }
                res+=_to_string(count);
                i += count;
            }
            else
            {
                res+=_to_string(1);
                i++;
            }
        }

 1002. 查找共用字符

1002. 查找共用字符icon-default.png?t=MBR7https://leetcode.cn/problems/find-common-characters/

给你一个字符串数组 words ,请你找出所有在 words 的每个字符串中都出现的共用字符( 包括重复字符),并以数组形式返回。你可以按 任意顺序 返回答案。

示例 1:

输入:words = ["bella","label","roller"]
输出:["e","l","l"]

示例 2:

输入:words = ["cool","lock","cook"]
输出:["c","o"]

提示:

    1 <= words.length <= 100
    1 <= words[i].length <= 100
    words[i] 由小写英文字母组成

【解法一】我的第一个理解题意出错的解法

第一次没有注意题目意思,将每个单词中重复出现多次的单词直接当成一次进行输出

仅仅完成了蓝色 ‘l’的输出,将绿色的‘l’没有进行输出。

 采用的思想是 首先初始化res,利用第一个单词中的每一个元素来进行其余单词的find查找

 然后对res进行去重操作。

class Solution {
public:
    vector<string> delete_repeat(vector<string> v)
        {
            sort(v.begin(), v.end());
            for(int i = 0; i < v.size(); ++i)
            {
                string temp = v[i];
                int j = i;
                while(j < v.size() && temp == v[j])
                {
                    j++;
                }
                v.erase(v.begin()+i+1, v.begin()+j);
            }
            return v;
        }
    vector<string> commonChars(vector<string>& words) {
        vector<string> res;
        for(int i = 0; i < words[0].size(); ++i)
        {
            char ch = words[0][i];
            int flag = 1;
            for(int j = 1; j < words.size(); ++j)
            {
                size_t pos = words[j].find(ch);
                if(pos==-1)
                {
                    flag = 0;
                    break;
                }
            }
            if(flag)
                res.push_back(string(1, ch));
        }
        return delete_repeat(res);
    }
};

【解法二】初步使用哈希思想

初始化一个vv数组进行对每个单词的的每个字符进行遍历,将单词字符出现次数进行统计

然后 分别每个字母在对应vv【字母下标】数组中值最小的次数,也就是公共出现次数

把这个字母往返回数组中存放入对应最小次数,如果没有出现那么就不存这个字母了。

 

class Solution {
public:
    vector<string> commonChars(vector<string>& words) {
        vector<string> res;
        vector<vector<int>> vv(words.size(), vector<int>(26, 0));
        for(int i = 0; i < words.size(); ++i)
        {
            for(int j = 0; j < words[i].size(); ++j)
            {
                vv[i][words[i][j]-'a']++;
            }
        }
        for(int i = 0; i < 26; ++i)
        {
            int minsize = vv[0][i];
			for (int j = 1; j < vv.size(); ++j)
            {
                minsize = min(vv[j][i], minsize);
            }
            if(minsize > 0)
            {
                for(int k = 0; k < minsize; k++)
                {
                    char ch = 'a'+i;
                    string s(1, ch);
                    res.push_back(s);
                }
            }
        }
        return res;
    }
};

【解法三】使用Hash

其实我的解法二就是采用了hash映射的思想解法三就是与我的解法存在着相同的思想

① 用第一个单词初始化Hash【26】数组,Hash存放第一个单词每个字母出现次数

② 对剩余其他单词进行哈希映射

       ③ 定义一个otherHash数组(注意它的位置,应该是遍历每个单词之前进行初始化,我刚开始

       与hash一起初始化导致错误)

       ④ 将每个单词出现次数映射到该otherHash数组中

       ⑤ 接着 对之前的Hash数组与otherHash数组进行更新处理,使Hash数组始终存放当前每个字

            母出现的最小次数(即为公共次数)

⑥ 对Hash进行遍历 将公共出现次数大于0的元素进行多次插入到返回数组中

class Solution {
public:
    vector<string> commonChars(vector<string>& words) {
        int hash[26] = {0};
        for(int i = 0; i < words[0].size(); ++i)
        {
            hash[words[0][i]-'a']++;
        }
        for(int i = 1; i < words.size(); ++i)
        {
            int otherhash[26] = {0};
            for(int j = 0; j < words[i].size(); ++j)
            {
                otherhash[words[i][j]-'a']++;
            }
            for(int k = 0; k < 26; k++)
            {
                hash[k] = min(hash[k], otherhash[k]);
            }
        }
        vector<string> res;
        for(int i = 0; i < 26; i++)
        {
            if(hash[i]>0)
            {
                for(int j = 0; j < hash[i]; ++j)
                {
                    char ch = 'a'+i;
                    res.push_back(string(1, ch));
                }
            }
        }
        return res;
    }
};

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

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

相关文章

稀疏矩阵向量乘法的openmp并行优化

稀疏矩阵向量乘法 添加链接描述本人在这篇博客已经介绍过稀疏矩阵向量乘法以及相关的一些存储方式,这里重点开始介绍openmp的并行优化。 下面这个图片就是采用CSR格式读取稀疏矩阵向量乘法的主体架构,全称为Compressed Sparse Row Matrix压缩稀疏矩阵行格式,该格式对矩阵进…

MyBatis【MyBatis的增删改查操作与单元测试】

MyBatis【MyBatis的增删改查操作与单元测试】&#x1f34e;一.单元测试&#x1f352;1.1 什么是单元测试&#xff1f;&#x1f352;1.2 单元测试好处&#x1f352;1.3 Spring Boot 框架 单元测试使用&#x1f352;1.4 单元测试实现&#x1f352;1.5 断言&#x1f34e;二.MyBati…

性能测试-微服务性能压测监控和调优【重点】【杭州多测师_王sir】【杭州多测师】...

本文主要内容一、何为压力测试1.1、 大白话解释性能压测是什么&#xff1a;就是考察当前 软件和硬件环境下&#xff0c;系统所能承受的最大负荷&#xff0c;并帮助找出系统的瓶颈所在。性能压测的目的&#xff1a;为了系统在线上的 处理能力和稳定性维持在一个标准范围内&#…

【MySQL】MySQL存储过程与存储函数实战(MySQL专栏启动)

&#x1f4eb;作者简介&#xff1a;小明java问道之路&#xff0c;专注于研究 Java/ Liunx内核/ C及汇编/计算机底层原理/源码&#xff0c;就职于大型金融公司后端高级工程师&#xff0c;擅长交易领域的高安全/可用/并发/性能的架构设计与演进、系统优化与稳定性建设。 &#x1…

LeetCode题解 二叉树(九):106 中序和后序遍历序列构造二叉树;105 从前序与中序遍历序列构造二叉树

下面要讲的两道题&#xff0c;从二叉树的角度来讲&#xff0c;是非常重要的&#xff0c;此前一直是遍历二叉树&#xff0c;现在就要根据数组&#xff0c;构造二叉树 106 从中序与后序遍历序列构造二叉树 medium 示例&#xff1a;中序遍历 inorder [9,3,15,20,7] 后序遍历 po…

SpringBoot做个埋点监控

JVM应用度量框架Micrometer实战 前提 spring-actuator做度量统计收集&#xff0c;使用Prometheus&#xff08;普罗米修斯&#xff09;进行数据收集&#xff0c;Grafana&#xff08;增强ui&#xff09;进行数据展示&#xff0c;用于监控生成环境机器的性能指标和业务数据指标。…

Three.js一学就会系列:04 炫酷3D文字

系列文章目录 Three.js一学就会系列&#xff1a;01 第一个3D网站 Three.js一学就会系列&#xff1a;02 画线 Three.js一学就会系列&#xff1a;03 炫酷3D划线 文章目录系列文章目录前言一、创建一个vue项目二、安装及使用安装创建一个dom元素三、核心代码讲解场景处理“雾”光…

83.【JQuery.Ajax】

Ajax(一)、Ajax简介1.什么是Ajax2.jQuery.ajax介绍(二)、环境搭建1.创建Model并添加web框架2.配置Artifacts的lib文件3.配置web框架下的web.xml4.配置spring-mvc.xml配置文件5.配置汇总文件applicationContexe.xml6.进行测试(三)、伪造Ajax1.iframe内敛框架伪造Ajax(四)、使用真…

【阶段二】Python数据分析NumPy工具使用01篇:NumPy工具介绍、NumPy工具安装与数组的创建

本篇的思维导图: NumPy工具介绍 NumPy(Numerical Python) 是 Python 语言的一个扩展程序库,支持大量的维度数组与矩阵运算,这个包封装了多个可以用于数组间计算的函数供你直接调用,是一个运行速度非常快的数学库。 NumPy工具安装 代码 结果

从输入URL到渲染的过程中到底发生了什么?

CDN缓存DNSTCP三次握手、四次挥手浏览器渲染过程输入URL到页面渲染过程的一些优化 下面我将“从输入URL到渲染的全过程”大概的描述出来&#xff0c;再对其过程加以解释&#xff0c;了解过程中可以做哪些优化。文章内容有点长&#xff0c;需要有足够的耐心看完哟&#xff01;&…

MySQL数据库高级面试题(2)

✅作者简介&#xff1a;热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏&#xff1a;Java面试题…

【自学Java】Java if else-if else语句

Java else if Java else if教程 在 Java 语言 中&#xff0c;关键字 if 是用于测试某个条件&#xff08;布尔型 或逻辑型&#xff09;的语句是否满足一定的条件&#xff0c;如果满足特定的条件&#xff0c;则会执行 if 后由大括号 {} 括起来的代码块&#xff0c;否则就忽略该…

利用Dlib 实现人脸68个特征点的标定

系列文章目录 文章目录系列文章目录前言1. 开发环境依赖2. 设计流程68个特征点提取&#xff1a;OpenCv 绘图&#xff1a;3. 源码OpenCv 的画图函数1. 画圆2. 写字符3.关于 颜色数组&#xff1a;前言 利用 Dlib 官方训练好的模型 “shape_predictor_68_face_landmarks.dat” 进…

【C语言 数据结构】树

文章目录树一、树的概念二、树的应用1&#xff09;树可表示具有分枝结构关系的对象2&#xff09;树是常用的数据组织形式三、树的表示四、树的基本术语五、树的四种表示方法5.1 双亲表示法5.2 孩子表示法5.3 双亲孩子表示法5.4 孩子兄弟表示法树 一、树的概念 树形结构是一种…

Git基础知识学习

1. Git工作机制 Workspace&#xff1a; 工作区&#xff0c;就是你平时存放项目代码的地方Index / Stage&#xff1a; 暂存区&#xff0c;用于临时存放你的改动&#xff0c;事实上它只是一个文件&#xff0c;保存即将提交到文件列表信息Repository&#xff1a; 仓库区&#xff0…

CleanMyMac4.12.3全新版本Mac清理优化工具

CleanMyMac X是一款超好用的Mac清理优化工具&#xff0c;可以帮助用户删除系统垃圾、不需要的应用程序和恶意软件&#xff0c;并调整您的 Mac 以获得最大速度&#xff01; CleanMyMac X作为一款知名的系统清理软件&#xff0c;深受广大用户们的喜爱。它操作简洁&#xff0c;能够…

Mycat2(三)mycat2搭建读写分离

文章目录一、mycat一主一从读写分离原理二、搭建MySQL主从复制三、配置mycat2一主一从读写分离四、配置Mycat2双主双从读写分离4.1 Mysql 双主双从搭建步骤1、创建MySQL数据库与MySQL 机器信息2、双柱双从配置2.1 master1配置2.2 master2配置2.3 Slave1、Slave2 配置3、在两台主…

程序员如何在职场上走得更远一些?

一. 工作心态 首先第一个要聊的啊就是这个心态的问题&#xff0c;我觉得有时候可以改变一下自己的心态&#xff0c;可以尝试把工作当成一种投资&#xff0c;或者说呢把工作当成一种自己的产品来经营&#xff0c;把目光多多的聚焦在这个收获和成长上面啊这样一个心态来应对&…

KV数据分片和分布

KV数据分片和分布 KV存储数据组织方式 Hash&#xff1a;对于Hash方式&#xff0c;键值对数据的存储位置由预定义的Hash函数确定&#xff0c;因此所有键值对数据不是有序排列。Hash方式的优点是通过Hash函数计算存储位置的效率高&#xff0c;因此处理插入、删除、更新、单点查…

MySQL之事务

引入事务&#xff1a; 一个事务其实就是一个完整的业务逻辑&#xff0c;它是一个最小的工作单元&#xff0c;是不可再分的。 那么什么是一个完整的业务逻辑呢&#xff1f; 拿现实生活中的银行业务举例&#xff0c;假设转账&#xff0c;从A账户向B账户中转账10000&#xff0c…