Leetcode刷題詳解——字符串中的第一個唯一字符

1. 題目鏈接:387. 字符串中的第一個唯一字符

2. 題目描述:

給定一個字符串 s ,找到 它的第一個不重復的字符,并返回它的索引 。如果不存在,則返回 -1

示例 1:

輸入: s = "leetcode"
輸出: 0

示例 2:

輸入: s = "loveleetcode"
輸出: 2

示例 3:

輸入: s = "aabb"
輸出: -1

提示:

  • 1 <= s.length <= 105
  • s 只包含小寫字母

3. 解法:

3.1 算法思路:

  1. 首先,獲取輸入字符串的長度,存儲在變量size中。
  2. 創建一個長度為256的整數數組count,用于存儲每個字符出現的次數。這里假設輸入字符串只包含ASCII字符,因此數組大小為256。
  3. 使用一個循環遍歷輸入字符串中的每個字符,統計每個字符出現的次數。將字符對應的ASCII碼作為數組下標,將對應位置的值加1。
  4. 再次使用一個循環遍歷輸入字符串中的每個字符,檢查其出現次數是否為1。如果某個字符出現次數為1,則返回該字符在字符串中的索引。
  5. 如果循環結束后仍未找到只出現一次的字符,則返回-1,表示沒有符合條件的字符。

3.2 C++算法代碼:

class Solution {
public:int firstUniqChar(string s) {int size = s.size(); // 獲取字符串長度int count[256] = {0}; // 初始化一個長度為256的數組,用于存儲每個字符出現的次數for (int i = 0; i < size; i++) {count[s[i]] += 1; // 統計每個字符出現的次數}for (int i = 0; i < size; i++) {if (1 == count[s[i]]) { // 如果某個字符出現次數為1,返回其索引return i;}}return -1; // 如果沒有找到只出現一次的字符,返回-1}
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/215435.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/215435.shtml
英文地址,請注明出處:http://en.pswp.cn/news/215435.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

spring 屬性注入 @Autowired和@Resource注解使用

眾所周知Resource 和 Autowired兩大注解是開發中最常用的兩大注解。兩者有一定的區別&#xff1a; Autowired Autowired是spring框架提供的注解類&#xff0c;默認按照類型進行裝配。當在容器中找不到對應類型的bean時會拋出NoSuchBeanDefinitionException異常&#xff0c;當…

C語言中的結構體成員賦值與訪問詳解

C語言中的成員賦值與訪問 在C語言中&#xff0c;我們可以使用不同的方式對結構體變量的成員進行賦值和訪問。本文將詳細介紹這些方式&#xff0c;并通過具體的示例代碼加以說明。 目錄 使用strcpy_s函數賦值字符串直接賦值數字和浮點數結構體變量之間的賦值使用復合文字進行…

周周清(2)----踩坑日記

周一&#xff1a; 1.之前換了一個jdk&#xff0c;然后又改了很多東西&#xff0c;很亂&#xff0c;以至于很多項目都不能直接運行了&#xff0c;所以今天就將ideal刪除并且更新版本到2022.3.3&#xff0c;并且重新將ideal里面的配置環境變量&#xff0c;以及jdk下載安裝配置&a…

數據庫系列之簡要對比下GaussDB和OpenGauss數據庫

GaussDB作為一款企業級的數據庫產品&#xff0c;和開源數據庫OpenGauss之間又是什么樣的關系&#xff0c;剛開始接觸的時候是一頭霧水&#xff0c;因此本文簡要對比下二者的區別&#xff0c;以加深了解。 1、GaussDB和OpenGauss數據庫簡要對比 GaussDB是華為基于PostgreSQL數據…

WPF仿網易云搭建筆記(4):信息流控制之消息訂閱

文章目錄 專欄和Gitee倉庫前言消息訂閱最簡單的案例簡單用例父組件訂閱子組件回調 結果 消息訂閱機制消息token是A還是B?傳遞消息的載體。雙重token重復訂閱問題 結論 專欄和Gitee倉庫 WPF仿網易云 Gitee倉庫 WPF仿網易云 CSDN博客專欄 前言 上一篇文章中&#xff0c;我們簡單…

PHP基礎(1)

PHP是一種服務器端腳本語言&#xff0c;是一種用于開發動態Web應用程序的最流行和廣泛使用的語言之一。它的全稱為“Hypertext Preprocessor”&#xff0c;是一種開源的、可嵌入HTML的腳本語言&#xff0c;可以嵌入到HTML中&#xff0c;也可以直接作為命令行腳本運行。PHP腳本在…

Java小案例-如果您的 Java 應用程序在不做任何事情時正在消耗 CPU,您如何確定它在做什么?

前言 我正在調用供應商的 Java API&#xff0c;在某些服務器上&#xff0c;JVM 在登錄 API 后似乎進入了低優先級輪詢循環&#xff08;CPU 使用率為 100%&#xff09;。其他服務器上的同一應用程序不會出現此行為。這發生在 WebSphere 和 Tomcat 上。環境設置起來很棘手&#…

DevOps搭建(四)-GitLab安裝細步驟

在這里我們用docker安裝 1、創建gitlab安裝目錄 mkdir -p /usr/local/docker/gitlab_docker 進入該目錄 cd /usr/local/docker/gitlab_docker 2、下載gitlab鏡像 docker pull gitlab/gitlab-ce:latest 3、創建docker-compose.yml vi docker-compose.yml 輸入以下內容保…

理解 HTTP POST 請求:表單與 JSON 數據格式深入解析20231208

引言 在日常的 Web 開發中&#xff0c;理解 HTTP POST 請求的不同數據格式是至關重要的。這不僅有助于構建健壯的后端服務&#xff0c;還能確保與其他服務的有效溝通。本文將深入探討 multipart/form-data 和 application/json&#xff0c;這兩種常見的 POST 請求格式。 POST…

2023 年安徽省職業院校技能大賽高職組“軟件測試”賽項樣題

2023 年安徽省職業院校技能大賽 高職組“軟件測試”賽項樣題 目錄 任務一&#xff1a;功能測試&#xff08;45 分&#xff09; 1、測試計劃&#xff08;5 分&#xff09; 2、測試用例&#xff08;15 分&#xff09; 3、Bug 清單&#xff08;20 分&#xff09; 4、測試報告&…

Python 學習筆記之 networkx 使用

介紹 networkx networkx 支持創建簡單無向圖、有向圖和多重圖&#xff1b;內置許多標準的圖論算法&#xff0c;節點可為任意數據&#xff1b;支持任意的邊值維度&#xff0c;功能豐富&#xff0c;簡單易用 networkx 中的 Graph Graph 的定義 Graph 是用點和線來刻畫離散事物…

張馳咨詢:數據驅動的質量改進,六西格瑪綠帶在汽車業實踐

尊敬的汽車行業同仁們&#xff0c;您是否曾面臨生產效率低下、成本不斷攀升或顧客滿意度下降的困擾&#xff1f;本期專欄&#xff0c;我們將深入探討如何通過六西格瑪綠帶培訓&#xff0c;在汽車行業中實現過程優化和質量提升。 汽車行業的競爭日趨激烈&#xff0c;致力于提供…

3.cloud-Consul服務注冊與發現

1.官網 https://learn.hashicorp.com/consul/getting-started/install.html 2.訂單服務 2.1 POM <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-discovery</artifactId> </dependenc…

學習Java第66天,路徑問題

相對路徑情況分析 相對路徑情況1:web/index.html中引入web/static/img/logo.png 訪問index.html的url為 : http://localhost:8080/web03_war_exploded/index.html 當前資源為 : index.html 當前資源的所在路徑為 : http://localhost:8080/web03_war_exploded/ 要獲取的目標資…

【華為數據之道學習筆記】3-9元數據治理面臨的挑戰

華為在進行元數據治理以前&#xff0c;遇到的元數據問題主要表現為數據找不到、讀不懂、不可信&#xff0c;數據分析師們往往會陷入數據沼澤中&#xff0c;例如以下常見的場景。 某子公司需要從發貨數據里對設備保修和維保進行區分&#xff0c;用來不對過保設備進行服務場景分析…

Qt 使用百度的離線地圖

使用百度離線地圖&#xff0c;一下載百度離線包&#xff08;offlinemap&#xff09;&#xff1b;二是準備地圖瓦片&#xff08;不同級別的瓦片&#xff09;&#xff1b;三 準備&#xff48;&#xff54;&#xff4d;&#xff4c;主頁面&#xff1b;四&#xff0c;&#xff31;&…

深度學習 Day13——P2彩色圖片分類

&#x1f368; 本文為&#x1f517;365天深度學習訓練營 中的學習記錄博客&#x1f356; 原作者&#xff1a;K同學啊 | 接輔導、項目定制 文章目錄 前言1 我的環境2 代碼實現與執行結果2.1 前期準備2.1.1 引入庫2.1.2 設置GPU&#xff08;如果設備上支持GPU就使用GPU,否則使用C…

在Go中定義方法

引言 函數允許你將邏輯組織到可重復的過程中,每次運行時可以使用不同的參數。在定義函數的過程中,你會經常發現多個函數可能每次都操作同一段數據。Go可以識別這種模式,并允許您定義特殊的函數,稱為方法,其目的是對某些特定類型的實例進行操作,稱為接收器。為類型添加方…

nodejs微信小程序+python+PHP基于spark的酒店管理系統-計算機畢業設計推薦

目 錄 摘 要 I ABSTRACT II 目 錄 II 第1章 緒論 1 1.1背景及意義 1 1.2 國內外研究概況 1 1.3 研究的內容 1 第2章 相關技術 3 2.1 nodejs簡介 4 2.2 express框架介紹 6 2.4 MySQL數據庫 4 第3章 系統分析 5 3.1 需求分析 5 3.2 系統可行性分析 5 3.2.1技術可行性&#xff1a;…

排序算法——歸并排序

歸并排序&#xff08;Merge Sort&#xff09;是計算機科學中非常重要的排序算法之一。它不僅高效、穩定&#xff0c;而且是許多高級排序技術和算法思想的基礎。在本文中&#xff0c;我們將深入探討歸并排序的原理、實現方法&#xff0c;以及它的優缺點。 1. 歸并排序的原理 歸…