当前位置: 首页 > news >正文

leetcode 找不同

389. 找不同

已解答

简单

相关标签

相关企业

给定两个字符串 s 和 t ,它们只包含小写字母。

字符串 t 由字符串 s 随机重排,然后在随机位置添加一个字母。

请找出在 t 中被添加的字母。

示例 1:

输入:s = "abcd", t = "abcde"
输出:"e"
解释:'e' 是那个被添加的字母。

示例 2:

输入:s = "", t = "y"
输出:"y"

提示:

  • 0 <= s.length <= 1000
  • t.length == s.length + 1
  • s 和 t 只包含小写字母
class Solution:def findTheDifference(self, s: str, t: str) -> str:# 将字符串s中的字符进行排序,并在末尾添加一个空格,以便在后续的比较中能够区分s和t的不同s = sorted(s) + [' ']# 将字符串t中的字符进行排序t = sorted(t)# 使用zip函数同时迭代两个排序后的字符串列表for i, b in zip(s, t):# 如果在迭代过程中发现两个字符串的对应字符不相等if i != b:# 返回t中的那个不同的字符return b

要找出在字符串 t 中被添加的字母,我们可以利用字符频率的概念。由于 st 只包含小写字母,我们可以创建一个计数器来统计 s 中每个字母出现的次数,然后遍历 t 并更新这个计数器。最后,那个在 t 中出现次数比 s 多一次的字母就是被添加的字母。

以下是解决这个问题的算法步骤:

  1. 创建一个大小为26的数组 count,用于存储每个字母的频率,初始值都为0。
  2. 遍历字符串 s,对于 s 中的每个字符,增加 count 数组中对应字母的计数。
  3. 遍历字符串 t,对于 t 中的每个字符,如果 count 数组中对应字母的计数不为0,就减1,直到找到计数为0的字母,这个字母就是被添加的字母。
  4. 返回找到的被添加的字母。
class Solution:def findTheDifference(self, s: str, t: str) -> str:count = [0] * 26  # 初始化计数器数组for char in s:   # 遍历字符串scount[ord(char) - ord('a')] += 1  # 更新s中每个字母的计数for char in t:   # 遍历字符串tif count[ord(char) - ord('a')] == 0:  # 如果计数为0,说明是被添加的字母return charelse:count[ord(char) - ord('a')] -= 1  # 否则,更新计数
class Solution:def findTheDifference(self, s: str, t: str) -> str:return (Counter(t) - Counter(s)).popitem()[0]

使用了 Python 的 collections 模块中的 Counter 类来统计字符串中每个字符的出现次数。

  1. class Solution: 定义了一个名为 Solution 的类,这个类将包含解决这个问题的方法。

  2. def findTheDifference(self, s: str, t: str) -> str: 定义了一个名为 findTheDifference 的方法,它接受两个字符串参数 st,并返回一个字符串,即在 t 中被添加的字母。

  3. return (Counter(t) - Counter(s)).popitem()[0] 是这个方法的核心逻辑:

    • Counter(t) 创建一个 Counter 对象,统计字符串 t 中每个字符的出现次数。
    • Counter(s) 创建另一个 Counter 对象,统计字符串 s 中每个字符的出现次数。
    • Counter(t) - Counter(s) 执行两个 Counter 对象的差集操作,结果是一个 Counter 对象,其中包含在 t 中出现次数多于 s 的字符及其出现次数。
    • .popitem() 方法从 Counter 对象中弹出(并返回)一个包含键值对的元组,这个键值对是 Counter 对象中的一个项。由于我们只关心那个多出来的字符,所以这里使用 popitem() 方法来获取这个字符。
    • [0] 表示返回元组中的第一个元素,即字符本身。

这段代码的逻辑是,由于 t 是由 s 随机重排后添加一个字母形成的,所以 t 中多出来的那个字母在 Counter(t) 中的计数会比 Counter(s) 中的计数多1。通过计算两个 Counter 对象的差集,我们可以直接找到这个多出来的字母。

这种方法的时间复杂度是 O(n),其中 n 是字符串的长度,因为我们需要遍历整个字符串来构建 Counter 对象。空间复杂度也是 O(n),因为我们需要存储两个字符串中所有字符的计数。

 

相关文章:

leetcode 找不同

389. 找不同 已解答 简单 相关标签 相关企业 给定两个字符串 s 和 t &#xff0c;它们只包含小写字母。 字符串 t 由字符串 s 随机重排&#xff0c;然后在随机位置添加一个字母。 请找出在 t 中被添加的字母。 示例 1&#xff1a; 输入&#xff1a;s "abcd"…...

2025 - 生信信息学 - GEO数据分析 - RF分析(随机森林)

GEO数据分析 - RF分析&#xff08;随机森林&#xff09; 01 准备数据文件 #install.packages("randomForest")#引用包 library(randomForest) set.seed(123456)inputFile"diffGeneExp.txt" #输入文件 setwd("/Users/wangyang/Desktop/BCBM/02ra…...

Matlab深度学习(四)——AlexNet卷积神经网络

网络搭建参考&#xff1a;手撕 CNN 经典网络之 AlexNet&#xff08;理论篇&#xff09;-CSDN博客 在实际工程应用中&#xff0c;构建并训练一个大规模的卷积神经网络是比较复杂的&#xff0c;需要大量的数据以及高性能的硬件。如果通过训练好的典型网络稍加改进&#xf…...

etcd defrag

场景 prometheus监控告警,告警信息如下 etcd cluster "kube-etcd": database size in use on instance xx is 33.45% of the actual allocated disk space, please run defragmentation (e.g. etcdctl defrag) to retrieve the unused fragmented disk space.处理…...

golang语言整合jwt+gin框架实现token

1.下载jwt go get -u github.com/dgrijalva/jwt-go2.新建生成token和解析token文件 2.1 新建common文件夹和jwtConfig文件夹 新建jwtconfig.go文件 2.2 jwtconfig.go文件代码 /* Time : 2021/8/2 下午3:03 Author : mrxuexi File : main Software: GoLand */ package jwtC…...

数据治理、数据素养和数据质量管理:文献综述

注意&#xff1a;这并不是正式发表的论文&#xff0c;只是一篇用来交作业的文章 摘要 随着数据时代的到来&#xff0c;数据治理、数据素养和数据质量管理成为组织数据管理中的三大核心概念。本文基于相关研究与实践&#xff0c;对这三个领域进行全面综述&#xff0c;探讨它…...

【Linux】用户和用户组管理

管理用户 1&#xff0e;添加用户账号——useradd命令 【实例2-1-1】 按系统默认配置添加指定用户账号st和stu。 # 添加用户账号st [rootlocalhost ~]# useradd st # 添加用户账号stu [rootlocalhost ~]# useradd stu【实例2-1-2】添加用户账号stu01&#xff0c;UID为1004&am…...

游戏引擎学习第16天

视频参考:https://www.bilibili.com/video/BV1mEUCY8EiC/ 这些字幕讨论了编译器警告的概念以及如何在编译过程中启用和处理警告。以下是字幕的内容摘要&#xff1a; 警告的定义&#xff1a;警告是编译器用来告诉你某些地方可能存在问题&#xff0c;尽管编译器不强制要求你修复…...

如何通过对敏捷实践的调整,帮助远程团队提升研发效能?

首先明确一点&#xff0c;最敏捷的做法就是不要远程团队或分布式团队&#xff0c;远程一定比不上面对面同一地点的模式&#xff0c;毕竟环境不同&#xff0c;就不要期望远程团队和本地团队具备相同的效能&#xff0c;甚至期望更高。 那么&#xff0c;无论何种原因&#xff0c;…...

Ubuntu Linux使用前准备动作 配置SSH

在 Ubuntu 系统中配置 SSH 服务可以通过以下步骤进行&#xff1a; 1、安装ssh服务 1&#xff09;打开终端&#xff08;可以使用快捷键 Ctrl Alt T&#xff09;。 2&#xff09;运行以下命令安装 OpenSSH 服务器&#xff1a; sudo apt-get update&#xff1a;这一步是更新…...

疫情下的图书馆管理系统:Spring Boot技术

摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了疫情下图书馆管理系统的开发全过程。通过分析疫情下图书馆管理系统管理的不足&#xff0c;创建了一个计算机管理疫情下图书馆管理系统的方案。文章介绍了疫情下图…...

vue3完整安装并创建项目

1、下载&#xff1a;https://npmmirror.com/mirrors/node/v18.19.0/node-v18.19.0-x64.msi 2、验证Nodejs是否安装成功&#xff08;管理员身份运行cmd&#xff09; node -v #查看nodejs的版本 v18.19.0npm -v #查看npm的版本 10.2.3 3、在D:\Program Files\nodejs路径下创建两…...

【Linux】Linux入门实操——进程管理(重点)

1. 概述 在 LINUX 中&#xff0c;每个执行的程序都称为一个进程。每一个进程都分配一个ID号(pid,进程号)。>windows > linux每个进程都可能以两种方式存在的。前台与后台&#xff0c;所谓前台进程就是用户目前的屏幕上可以进行操作的。后台进程则是实际在操作&#xff0…...

Linux-Apache

文章目录 Apache基础配置 &#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f916;Linux专栏&#xff1a;点击&#xff01; ⏰️创作时间&#xff1a;2024年11月19日12点20分 Apache Web服务器用来实现HTTP和相关TCP连接的处理&#xff0c;同时负责所提供资源的管理…...

高危,Laravel参数注入漏洞安全风险通告

今日&#xff0c;亚信安全CERT监控到安全社区研究人员发布安全通告&#xff0c;披露了Laravel 参数注入漏洞(CVE-2024-52301)。在受影响的版本中&#xff0c;Application.php 文件的 detectEnvironment 函数直接使用了 $_SERVER[argv]&#xff0c;但没有检查运行环境是否为 CLI…...

【Qt】使用QString的toLocal8Bit()导致的问题

问题 使用Qt发送一个Http post请求的时候&#xff0c;服务一直返回错误和失败信息。同样的url以及post参数&#xff0c;复制黏贴到postman里就可以发送成功。就感觉很神奇。 原因 最后排查出原因是因为参数中含有汉字而导致的编码问题。 在拼接post参数时&#xff0c;使用了…...

Android上运行Opencv(TODO)

在高通安卓平台上&#xff0c;确实可以通过 NDK 使用 OpenCV 并访问摄像头。NDK 提供了更高性能的计算能力&#xff0c;特别是在图像处理和计算密集型任务中&#xff0c;与 OpenCV 结合可以充分利用高通平台的硬件资源&#xff08;如 NEON SIMD 指令集和 GPU 加速&#xff09;。…...

动态IP黑白名单过滤的设计与实现(上篇设计思想)

文章目录 需求分析方案设计1、设计过程2、最终方案3、扩展知识 - 布隆过滤器 需求分析 一些恶意用户&#xff08;可能是黑客、爬虫、DDoS 攻击者&#xff09;可能频繁请求服务器资源&#xff0c;导致资源占用过高。因此我们需要一定的手段实时阻止可疑或恶意的用户&#xff0c…...

LeetCode 力扣 热题 100道(五)最长回文子串(C++)

最长回文子串 给你一个字符串 s&#xff0c;找到 s 中最长的 回文子串。 回文性 如果字符串向前和向后读都相同&#xff0c;则它满足 回文性 子字符串子字符串 是字符串中连续的 非空 字符序列。 动态规划法 class Solution { public:string longestPalindrome(string s) {i…...

Docker--Docker Registry(镜像仓库)

什么是Docker Registry&#xff1f; 镜像仓库&#xff08;Docker Registry&#xff09;是Docker生态系统中用于存储、管理和分发Docker镜像的关键组件。 镜像仓库主要负责存储Docker镜像&#xff0c;这些镜像包含了应用程序及其相关的依赖项和配置&#xff0c;是构建和运行Doc…...

收藏!8年传统后端转AI应用开发,2026年实战干货全拆解(小白/程序员必看)

本人做了8年传统后端开发&#xff0c;去年顶着30的年龄焦虑&#xff0c;果断跳出舒适圈&#xff0c;咬牙转型AI应用开发。这一年里&#xff0c;面试被面试官追问到哑口无言、项目落地踩遍各种坑、熬夜调试到凌晨都是常态&#xff0c;但所有付出都有回报&#xff1a;薪资直接上涨…...

嵌入式NMEA-0183零内存分配解析器设计与实现

1. NMEA-0183 协议解析库深度技术解析&#xff1a;面向嵌入式系统的轻量级、零内存分配实现 NMEA-0183&#xff08;National Marine Electronics Association 0183&#xff09;是全球航海电子设备事实上的标准通信协议&#xff0c;自1983年发布以来&#xff0c;已广泛应用于GPS…...

**发散创新:用Go语言构建高可用服务的故障演练自动化框架**在现代分布式系统中,**故障演练(Chaos Engine

发散创新&#xff1a;用Go语言构建高可用服务的故障演练自动化框架 在现代分布式系统中&#xff0c;故障演练&#xff08;Chaos Engineering&#xff09; 已成为保障生产环境稳定性的核心手段之一。它通过主动注入异常行为&#xff08;如网络延迟、服务宕机、资源耗尽等&#x…...

go实战案例:如何在 Go-kit 和 Service Meh 中进行服务注册与发现?

今天分享的是如何在Go-kit和ServiceMesh中进行服务注册与发现的案例。在上文中&#xff0c;我们基于搭建好的 Consul 集群&#xff0c;通过 Consul 中提供的 HTTP API 实现了 register 的服务注册与发现功能。我们采用手动构造HTTP请求的方式&#xff0c;在服务启动时发送服务实…...

《Linux 是怎样工作的》第 2 章:用户模式实现的功能

一、先建立核心认知&#xff1a;两个世界的边界 计算机系统被严格划分为两个隔离的运行环境&#xff0c;这是保障系统安全与稳定的基础&#xff1a; 内核态&#xff08;Kernel Mode&#xff09;&#xff1a;相当于「小区物业」&#xff0c;唯一能直接操作 CPU、内存、硬盘、网…...

OpenClaw任务调度:GLM-4.7-Flash定时执行方案

OpenClaw任务调度&#xff1a;GLM-4.7-Flash定时执行方案 1. 为什么需要定时任务调度 上周我需要每天凌晨自动生成一份技术日报&#xff0c;手动操作既耗时又容易遗忘。当我尝试用OpenClaw对接本地部署的GLM-4.7-Flash模型时&#xff0c;发现原生的对话式交互无法满足周期性任…...

OpenClaw+nanobot自动化处理客服常见问题

OpenClawnanobot自动化处理客服常见问题 1. 为什么选择OpenClawnanobot做客服自动化 去年夏天&#xff0c;我的个人项目突然迎来一波用户增长&#xff0c;随之而来的是每天上百条的客服咨询。当我连续三天凌晨两点还在回复"如何重置密码"这类问题时&#xff0c;终于…...

DAMA数据资产目录实战:从零搭建企业级数据管理系统的5个关键步骤

DAMA数据资产目录实战&#xff1a;从零搭建企业级数据管理系统的5个关键步骤 当企业数据量呈指数级增长时&#xff0c;最令人头疼的往往不是存储问题&#xff0c;而是"数据在哪&#xff1f;谁能用&#xff1f;怎么用&#xff1f;"这三个灵魂拷问。去年我们为一家中型…...

STM32CubeMX + HAL 库:定时器输入捕获的进阶应用,多通道PWM信号同步测量与动态分析

1. 多通道PWM信号同步测量的核心挑战 在电机控制或无人机舵机系统中&#xff0c;经常需要同时监测多个PWM信号的实时状态。比如四轴飞行器的四个电调信号&#xff0c;或者机械臂的六个关节舵机反馈。传统单通道测量方法需要轮流采样&#xff0c;无法捕捉各通道间的相位关系&…...

Java PPT自动化:从数据到演示文稿的智能生成

1. 为什么需要Java PPT自动化&#xff1f; 想象一下这样的场景&#xff1a;每周五下午&#xff0c;市场部的同事都会准时发来一封邮件&#xff0c;要求你根据本周的销售数据生成一份PPT报告。数据来自CRM系统&#xff0c;包含几十个SKU的销售额、增长率、区域分布等信息。你需要…...