一、题目解析

1、s[i]仅包含小写字母

2、字符串的长度为[0,100]

二、算法原理

解法1:哈希表

用哈希表记录s[i]的字符,如果有重复的,则返回false

优化1:由于s[i]中只有小写字母,所以可以创建一个int hash[26]的数组,0代表字符a

解法2/优化2:位图

一个int有32个比特位,我们可以用一个比特位代表一个小写字母,‘a’用0位比特位表示,0表示字符未存在,1表示字符存在

位运算公式:

 

三、代码示例

class Solution {
public:bool isUnique(string astr){if(astr.size() > 26) return false;int n = 0;for(auto& e : astr){if(((n>>(e-'a')) & 1) == 1)return false;if(((n>>(e-'a')) & 1) == 0)n |= (1<<(e-'a'));}return true;}
};

 

 

看到最后,如果对您有所帮助,还请点赞、收藏和关注,我们下期再见! 

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

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

相关文章

wsl /lib/x86_64-linux-gnu/libc.so.6: version GLIBC_2.28‘ not found

遇到的问题并没有解决&#xff0c;这个 glibc-2.28 应该是安装好了 Ubuntu18 问题描述&#xff1a;Ubuntu18 WSL 无法启动 VS Code &#xff0c;因为node版本问题 rootUbuntu18:~# code . /lib/x86_64-linux-gnu/libc.so.6: version GLIBC_2.28 not found (required by /root…

Windows系统ffmpeg.dll丢失怎么办?从错误分析到永久修复的完整流程

您是否遇到过这样的情况&#xff1a;打开心爱的视频编辑软件时&#xff0c;系统突然提示无法启动此程序&#xff0c;因为计算机中丢失ffmpeg.dll&#xff1f;别担心&#xff0c;这个问题比您想象的要常见得多。作为专业的技术支持团队&#xff0c;我们已经帮助数千用户解决了类…

LaTeX 复杂图形绘制教程:从基础到进阶

系列文章目录 第一章&#xff1a;深入了解 LaTeX&#xff1a;科技文档排版的利器 第二章&#xff1a;LaTeX 下载安装保姆级教程 第三章&#xff1a;LaTeX 创建工程并生成完整文档指南 第四章&#xff1a;LaTeX 表格制作全面指南 文章目录系列文章目录前言一、​LaTeX 绘图工具…

用 Go Typed Client 快速上手 Elasticsearch —— 从建索引到聚合的完整实战

1. 准备工作 go get github.com/elastic/go-elasticsearch/v9小贴士 如果你的集群启用了安全特性&#xff0c;需要在 elasticsearch.Config 中配置 Username/Password 或 APIKey。Typed Client 通过 NewTypedClient 创建&#xff0c;内部复用 *http.Client&#xff0c;建议全局…

《义龙棒球科普》棒球是韩国的国球吗·棒球1号位

⚾ Why Baseball is Koreas NATIONAL SPORT? | KBO热血全解析 ⚾⚾ 1. 历史根源 & 情感纽带 Historical Roots & Emotional Bond美军引入 (1945后): 战后美军将棒球带入韩国&#xff0c;迅速扎根&#xff01;✨1982 KBO成立: 亚洲第二个职业棒球联盟诞生&#xff01;奥…

三坐标测量机路径规划与补偿技术:如何用算法看见微米级误差?

三坐标测量的微米级精度背后&#xff0c;是精密的路径规划算法与实时补偿技术在保驾护航。三坐标测量机的智能避撞算法保障了测量的安全与高效&#xff1b;温度补偿技术消除了环境的无形干扰&#xff1b;点云智能处理则让海量数据蜕变为精准的工程决策依据。 “智能避让路径”&…

Docker设置容器时间

一、前言前言&#xff1a;容器搭建好之后&#xff0c;容器的默认时区于本地时区不一致&#xff0c;这将导致日志文件中保存的时间为错误时间。二、操作1、进入docker 容器docker exec -it <容器名称> bash2、选择时区tzselect3、配置时区根据跳出来的配置选择Asia -> …

德国威乐集团亚太中东非洲PMO负责人和继明受邀为PMO大会主持人

全国PMO专业人士年度盛会德国威乐集团亚太中东非洲PMO负责人 和继明先生 受邀为“PMO评论”主办的2025第十四届中国PMO大会主持人&#xff0c;敬请关注&#xff01;嘉宾介绍&#xff1a;和继明先生&#xff0c;德国威乐集团亚太中东非洲PMO负责人&#xff0c;项目管理硕士MPM&a…

idea 集成飞算Java AI 教程

idea 集成飞算Java AI 教程一、介绍二、下载安装 飞算Java AI 插件方式一&#xff1a;从idea插件市场安装方式二&#xff1a;下载离线安装包三、飞算Java AI插件使用一、介绍 ​ 随着人工智能技术的发展&#xff0c;AI 编程助手逐渐成为提升开发效率的强大工具。上一篇教程是i…

2025.8.1

代码练习 //用指针访问对象成员 #include<iostream> #include<string> using namespace std; class Champion { public:Champion(int id, string nm, int hp, int mn, int dmg) {ID id;name nm;HP hp;mana mn;damage dmg;}void attack(Champion& chmp) {c…

一种新的分布式ID生成方案--ULID

一种新的分布式ID生成方案 ULID: 一种新的分布式ID生成方案 ULID (Universally Unique Lexicographically Sortable Identifier) 是一种较新的分布式ID生成方案&#xff0c;旨在解决传统UUID和雪花算法(Snowflake)的一些局限性。ULID的主要特点 可排序性&#xff1a;ULID按生成…

服务器中涉及节流(Throttle)的硬件组件及其应用注意事项

服务器中涉及节流&#xff08;Throttle&#xff09;的硬件组件及其应用注意事项 在服务器硬件中&#xff0c;“节流”&#xff08;throttling&#xff09;是一种保护机制&#xff0c;当组件温度过高、功耗过大或超出安全阈值时&#xff0c;系统会自动降低性能&#xff08;如时钟…

GitPython07-源码解读

GitPython07-源码解读1 1-核心知识 1&#xff09;从核心代码的第一行作为突破口2&#xff09;从Repo.init方法入手做追踪3&#xff09;subprocess到底做了什么&#xff1f;gitPython是不是执行的脚本&#xff0c;最终还是通过subprocess做到的4&#xff09;代码中貌似并没有实…

Java继承机制详解:从原理到实战应用

一、继承的本质&#xff1a;消除冗余&#xff0c;构建逻辑关系想象一个公司管理系统&#xff1a;普通销售员工&#xff08;CommissionEmployee&#xff09;和带底薪销售员工&#xff08;BasePlusCommissionEmployee&#xff09;共享大部分属性&#xff08;姓名、工号、销售额、…

工业数采引擎-DTU

DTU配置注册包及心跳包(对应设备配置->设备SN)&#xff0c;模块工作方式&#xff1a;TcpClient&#xff0c;首次连接成功后&#xff0c;DTU发送上来的注册包作为链路SessionId1. ModbusRtu设备 -> Dtu -> Server2. DLT645设备 -> Dtu -> Server3. 自定义设备 -&…

AttributeError: ChatGLMTokenizer has no attribute vocab_size

请问运行下面语句tokenizer AutoTokenizer.from_pretrained("THUDM/chatglm-6b", trust_remote_codeTrue) 出现“AttributeError: ChatGLMTokenizer has no attribute vocab_size”是版本不一致&#xff0c;需要旧的版本卸载conda uninstall transformers或者pip un…

14.串口更新FLASH字库

一、简介 在使用STM32等单片机驱动显示屏时&#xff0c;为了显示中文字体&#xff0c;常用FLASH保存字库信息。但是字库的更新通常只能使用SD卡更新&#xff0c;在一些小型单片机系统(如STM32F103C8T6、STC89C52)上&#xff0c;没有增加SD卡支持的必要。为解决此问题&#xff0…

Lombok常用注解及功能详解

Lombok常用注解及功能详解一、Lombok简介与环境配置1.1 什么是Lombok&#xff1f;1.2 环境配置1.2.1 Maven项目1.2.2 Gradle项目1.2.3 IDE配置&#xff08;关键&#xff09;二、Lombok常用注解详解2.1 Data&#xff1a;一站式生成核心方法2.2 Getter/Setter&#xff1a;单独生成…

应用分层

应用分层是⼀种软件开发设计思想&#xff0c;它将应用程序分成N个层次&#xff0c;这N个层次分别负责各自的职责&#xff0c; 多个层次之间协同提供完整的功能。根据项目的复杂度&#xff0c;把项目分成三层&#xff0c;四层或者更多层。常见的MVC设计模式&#xff0c;就是应用…

[特殊字符] 【JAVA进阶】StringBuilder全方位解析:从使用到源码,一文搞定!

&#x1f525; 掌握StringBuilder&#xff0c;让你的Java字符串操作性能飙升&#xff01;&#x1f9e9; StringBuilder是什么&#xff1f; StringBuilder是Java中用于动态构建字符串的可变字符序列类&#xff0c;位于java.lang包中。与不可变的String类不同&#xff0c;StringB…