算法练习|Leetcode49字母异位词分词 ,Leetcode128最长连续序列,Leetcode3无重复字符的最长子串,sql总结

目录

  • 一、Leetcode49字母异位词分词
    • 题目描述
    • 解题思路
    • 方法:哈希
    • 总结
  • 二、Leetcode128最长连续序列
    • 题目描述
    • 解题思路
    • 方法:
    • 总结
  • 三、Leetcode3无重复字符的最长子串
    • 题目描述
    • 解题思路
    • 方法:双指针法
    • 总结
    • sql总结

一、Leetcode49字母异位词分词

题目描述

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

字母异位词 是由重新排列源单词的所有字母得到的一个新单词。

在这里插入图片描述

题目链接:力扣题目链接

解题思路

  • 看到小写字母,想到使用哈希ord
  • 将前面出现过的放在字典,再次出现相同的就append

方法:哈希

  • 要用两次循环做哈希,找到每个单层对应的哈希特征
  • 加入字典
  • 打印字典value
class Solution:def groupAnagrams(self, strs: List[str]) -> List[List[str]]:mp = defaultdict(list)for i in strs:# 把每个单词特征存好pre = [0] * 26for j in i:pre[ord(j) - ord("a")] += 1# 找之前是否出现过mp[tuple(pre)].append(i)return list(mp.values())

总结

  • 新建字典:mp = defaultdict(list),添加value时默认值是[]
  • 字典的key要唯一,数组作为key要变成元组tuple
  • 最终输出字典的所有value:list(mp.values())


二、Leetcode128最长连续序列

题目描述

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

在这里插入图片描述

题目链接:力扣题目链接

解题思路

  • 去重
  • 排序
  • 看下一位是不是当前位+1
  • 更新最大长度

方法:

  • 先用list(set())去重,sort()排序
  • 看下一位是不是当前位+1
  • 更新最大长度
  • 反之,长度变回1
class Solution:def longestConsecutive(self, nums: List[int]) -> int:if not nums:return 0nums = list(set(nums))  # 去除重复元素nums.sort()l = 1res = 1for i in range(len(nums)):cur = nums[i] if (i+1)<len(nums) and nums[i+1] == cur+1:l += 1res = max(res, l)else:l = 1return res

总结

  • 思考要不要排序,排序前要不要去重
  • 去除重复元素再排序!!list(set()),.sort()
  • 注意i+1不要超限!!


三、Leetcode3无重复字符的最长子串

题目描述

给定一个字符串 s ,请你找出其中不含有重复字符的 最长
子串的长度。

在这里插入图片描述

题目链接:力扣题目链接

解题思路

  • 双指针
  • 每走一步,用字典记录字符和下标
  • 出现重复的,移动left,更新right

方法:双指针法

  • 每走一步记录 字符:下标
  • 遇到重复的,left移动到之前记录的重复位置+1
  • 更新当前right位置的字典
  • 更新length
  • right += 1
class Solution:def lengthOfLongestSubstring(self, s: str) -> int:left, right = 0, 0length = 0dic = {}while right < len(s):if s[right] in dic and dic[s[right]] >= left:left = dic[s[right]] + 1dic[s[right]] = rightlength = max(length, right - left + 1)right += 1return length

总结

  • left的移动:
    字典中先判断有重复元素
    并且重复元素之前出现的位置在left右边
    移动到重复元素的右边一个位置


sql总结

  • 所有情况都满足才返回
    (当一个产品所有发布时间都要在时间范围内才返回id)
    用count检测:having count(x between ’ ’ and ’ ') = count(*)

心得:积累算法还是要多刷题,在进步了!~

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

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

相关文章

模板初阶

泛型编程&#xff1a; 泛型编程&#xff1a;编写与类型无关的通用代码&#xff0c;模板是泛型编程的基础 class Test { public:void Swap(int& left, int& right){int tmp left;left right;right tmp;}void Swap(double& left, double& right){double tmp…

AR HUD_VSLAM+显示技术

智能座舱的一个重要技术方向是表达与展示。HUD可以将驾驶相关的信息&#xff0c;如车速、导航等投射到驾驶员的视线上方&#xff0c;避免驾驶员的目光离开前方道路。这种显示方式可以提供关键信息的实时展示&#xff0c;减少驾驶员的分心。 HUD的技术原理就是通过光学系统将信息…

网络工程师----第十一天

OSPF&#xff1a; 对称加密算法&#xff1a; 也称为私钥加密或单密钥算法&#xff0c;是一种加密方式&#xff0c;其中加密和解密使用相同的密钥。这种算法的优点包括加密解密速度快、计算量小&#xff0c;适用于大量数据的加密。然而&#xff0c;它的缺点是密钥的安全性难以保…

入坑 Node.js 1

原文&#xff1a;https://blog.iyatt.com/?p14717 前言 前面刚刚对 Spring Boot 有了个概念&#xff0c;再来学学 Node.js&#xff0c;顺便当学 JavaScript&#xff0c;为后面入前端做准备。 环境 Node.js 20.12.2 官方 API 文档&#xff1a;https://nodejs.org/docs/lat…

前端CSS基础6(CSS列表与表格的相关属性,边框的样式调整)

前端CSS基础6&#xff08;CSS列表与表格的相关属性&#xff0c;边框的样式调整&#xff09; CSS列表相关属性CSS表格相关属性回忆表格边框相关属性单元格边框相关属性回忆单元格的跨行和跨列操作单元格边框的相关属性 CSS列表相关属性 在 CSS 中&#xff0c;列表&#xff08;L…

多元函数泰勒公式(含黑塞矩阵)

一元函数的泰勒公式&#xff1a; 接下来&#xff0c;由一元函数有关知识&#xff0c;我们有: 注意这里的dxn中&#xff0c;应把dx看作一个整体&#xff0c;即一个微小变量的n次方 我们接下来推导微分算子&#xff1a; 接下来&#xff0c;把一元泰勒公式转为微分形式: 对于二元…

arm架构,django4.2.7适配达梦8数据库

【Python相关包版本信息】 Django 4.2.7 django-dmPython 3.1.7 dmPython 2.5.5 【达梦数据库版本】 DM Database Server 64 V8 DB Version: 0x7000c 适配过程中发现的问题如下&#xff1a; 错误一&#xff1a;d…

OWASP发布十大开源软件安全风险及应对指南

​ 最近爆发的XZ后门事件&#xff0c;尽管未酿成Log4j那样的灾难性后果&#xff0c;但它再次敲响了警钟&#xff1a;软件供应链严重依赖开源软件&#xff0c;导致现代数字生态系统极其脆弱。面对层出不穷的安全漏洞&#xff0c;我们需要关注开源软件 (OSS)风险 &#xff0c;改进…

上海鑫吉百数——让制造型食品企业焕发新生机!

随着全球化和互联网的普及&#xff0c;食品行业的竞争也日益激烈。数字化转型有助于企业打破地域限制&#xff0c;拓宽市场渠道&#xff0c;提升品牌影响力和竞争力。在信息化、网络化的时代背景下&#xff0c;数字化转型成为企业适应社会发展的必然选择。消费者对于食品的需求…

照片相似性搜索引擎Embed-Photos;赋予大型语言模型(LLMs)视频和音频理解能力;OOTDiffusion的基础上可控制的服装驱动图像合成

✨ 1: Magic Clothing Magic Clothing是一个以可控制的服装驱动图像合成为核心的技术项目&#xff0c;建立在OOTDiffusion的基础上 Magic Clothing是一个以可控制的服装驱动图像合成为核心的技术项目&#xff0c;建立在OOTDiffusion的基础上。通过使用Magic Clothing&#xf…

Spring基础 SpringAOP

前言 我们都知道Spring中最经典的两个功能就是IOC和AOP 我们之前也谈过SpringIOC的思想 容器编程思想了 今天我们来谈谈SpringAOP的思想 首先AOP被称之为面向切面编程 实际上面向切面编程是面向对象的编程的补充和完善 重点就是对某一类问题的集中处理 前面我们写的统一异常管理…

hadoop安装记录

零、版本说明 centos [rootnode1 ~]# cat /etc/redhat-release CentOS Linux release 7.9.2009 (Core)jdk [rootnode1 ~]# java -version java version "1.8.0_311" Java(TM) SE Runtime Environment (build 1.8.0_311-b11) Java HotSpot(TM) 64-Bit Server VM (…