拿什么拯救你,我的面試之——從零打卡刷Leetcode(No.003)

寫在前邊:

小詹一直覺得自己編程能力不強,想在網上刷題,又怕不能堅持。不知道有木有和小伙伴和小詹一樣想找個人一起刷題呢?歡迎和小詹一起定期刷leetcode,每周一周五更新一題,每一題都吃透,歡迎一題多解,尋找最優解!歡迎小伙伴們把自己的思路在留言區分享出來噢

前期回顧:【記錄帖】(No.002)從零打卡刷Leetcode

【歡迎關注個人微信公眾號【小詹學python】】

上一期有留一個小bug讓小伙伴們找,不知道多少人自己找到了啊?愛學習的人肯定自己去嘗試了,肯定發現leetcode上運行結果發現輸出不是預期的[7, 0, 8],而是像下邊這樣:

Finished in 36 ms
[7, 0.6999999999999993, 8.07, 1]
復制代碼

一個不合預期的地方是出現了小數,還有一個則是鏈表長度不合預期。其實,這個是除法導致的,這里的除法保留了小數部分,導致進位標志carry不是我們需要的整型0或者1了,所以出現了小數,另一方面進位的錯誤也導致在最高位的時候再次進了一位,即鏈表中多出了個1。修改方法很簡單,只需要在兩處carry位置進行類型轉換,具體如下。或者注意''/''和“//”的區別,后者所除的結果僅保留商(整型),前者即存在小數。

carry = int(p.next.val / 10)  #int()強制轉換為整型
復制代碼

上期沒找出原因的小伙伴可以去改過來試試看噢~


No.3 Longest Substring without Repeating Characters

原題:

Given a string, find the length of the longest substring without repeating characters.

題目大意:給出一個字符串,找到最長的沒有重復字符的子字符串,并返回該子字符串的長度。

例如:

Given "abcabcbb", the answer is "abc", which the length is 3.
Given "bbbbb", the answer is "b", with the length of 1.
Given "pwwkew", the answer is "wke", with the length of 3. Note that the answer must be a substring, "pwke" is a subsequence and not a substring.
復制代碼

可能是前邊的題目都大同小異,難度也接近。也有可能是人的思維有慣性,小詹又是利用循環嵌套遍歷所有情況進行判斷的,這種簡單粗暴可以實現,但是效率很低。大體思路是:第一層循環從字符串的最左側到最右側第二個,即for i in range(0,len(s)-1),第二層循環則從第一層緊跟著的一個到最后一個字符。即for j in range(i+1,len(s));之后通過找出所有不重復的子字符串,比較長度得到最大長度的子字符串。代碼如下:(需要注意當字符串長度為0或1的特殊情況)

def lengthOfLongestSubstring(self, s):""":type s: str:rtype: int"""max_len = 0 #用這個值記錄我們要返回的最長子字符串長度#當原字符串長度為0或1的特殊情況if (len(s) == 1 or len(s) == 0):max_len = len(s)#開始遍歷每一個子字符串,并進行長度比較,得到最長的那個for i in range(0,len(s)-1):for j in range(i+1, len(s)):if s[j] in s[i:j]:if j-i > max_len:right = jleft = i#這里小詹本想返回對應子字符串的左右索引值,之后發現題目沒有要求max_len = right-leftbreakelif j == len(s) - 1:if max_len < j - i + 1:max_len = j - i + 1return max_len
復制代碼

結果當然是可以通過的啦,然而時間效率方面很差很差,如圖:

然而,我們不能滿足于這種最低效率的實現結果。下邊提出一個炒雞牛逼的方法,非原創,小詹花了很久才搞明白其思路,其利用到了字典的方法。什么是字典?請自行補充知識噢(公眾號有語法綜述)。先放代碼后再解釋:

def lengthOfLongestSubstring(self, s):""":type s: str:rtype: int"""#創建一個空字典,其存放的形式是“單字符:出現位置的索引”indexDict = {}#存放記錄最大長度和當前循環下的長度maxLength = currMax = 0for i in range(len(s)):#這里是關鍵,小詹看了挺久的,小伙伴們比我強,應該比較快#這里是當s[i]沒有在之前出現過,則當前長度currMax自動加一#當出現了重復字符,則比較當前找到的子字符串長度和歷史最大長度#重點是這里i - indexDict[s[i]] - 1 的含義;代碼后舉例具體講解if s[i] in indexDict and i - indexDict[s[i]] - 1 <= currMax:if maxLength < currMax:maxLength = currMaxcurrMax = i - indexDict[s[i]] - 1currMax = currMax + 1                indexDict[s[i]] = i return maxLength if currMax < maxLength else currMax
復制代碼

代碼里對應位置加入了注釋,理解起來應該好很多了,這里舉例說明下為什么【i - indexDict[s[i]] - 1】代表了當前找到子字符串的長度。

比如字符串'abcdadd',代碼運行過程中一直迭代到i=3【對應字符d】時,都不滿足s[i] in indexDict ,不執行條件語句,而是currMax依次加一,并且將字符信息以{s[i]:i}的形式存放在字典中。當繼續迭代i=4時,進入條件語句,這里主要解釋【i - indexDict[s[i]] - 1】,檢測到了重復字符'a',之前該字符出現位置為i=0處即【indexDict[s[i]] =0】這時候當前檢測到的無重復字符子串為'abcd',長度為【4-indexDict[s[i]] -1 = 4】。其他同此例。


往期推薦(關注微信公眾號【小詹學python】)

Python系列之——在北京當房奴的日子~

爬蟲和反反爬蟲(下篇)




?


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

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

相關文章

146. LRU 緩存機制

146. LRU 緩存機制 運用你所掌握的數據結構&#xff0c;設計和實現一個 LRU (最近最少使用) 緩存機制 。 實現 LRUCache 類&#xff1a; LRUCache(int capacity) 以正整數作為容量 capacity 初始化 LRU 緩存 int get(int key) 如果關鍵字 key 存在于緩存中&#xff0c;則返回…

[SQL] 請教一下 count里面有case when 一般情況下啥時候用

http://www.itpub.net/forum.php?modviewthread&tid1810967 問題: 比如 count(case when pday_id${deal_date} then 1 end) 我有點想不明白具體什么情況下count&#xff08;&#xff09; 這個小括號里面還要用case when 大家做BI統計的時候一般什么情況用啊 還有個…

路由器架設虛擬服務器讓外網訪問到本地網站

確定電腦與路由器正確連接&#xff0c;并且已連至互聯網。在地址欄中輸入192.168.0.1回車&#xff0c;輸入用戶名密碼&#xff0c;進入路由器主界面。 然后點擊左側菜單中的“虛擬服務器”&#xff0c;——“端口段映射”打開“端口段映射”界面。 由于網站用的是80端口&#x…

vue項目示例代碼git_您應該了解的5個Git命令以及代碼示例

vue項目示例代碼gitIve used Git for some years now, and I still find myself googling how to do some basic tasks. So this article is my attempt to learn how to do some of these things by writing about them. And even if I still forget, at least Ill have a ref…

413. 等差數列劃分

413. 等差數列劃分 如果一個數列 至少有三個元素 &#xff0c;并且任意兩個相鄰元素之差相同&#xff0c;則稱該數列為等差數列。 例如&#xff0c;[1,3,5,7,9]、[7,7,7,7] 和 [3,-1,-5,-9] 都是等差數列。 給你一個整數數組 nums &#xff0c;返回數組 nums 中所有為等差數組…

山羊與汽車游戲的實驗算法

實驗1&#xff1a; function shuffle(target) {var j, x, i target.length;for (; i > 0; j parseInt(Math.random() * i), x target[--i], target[i] target[j], target[j] x) {}return target }function removeAt(target, index) {return !!target.splice(index, 1).…

selenium模塊

selenium模塊 閱讀目錄 一 介紹二 安裝三 基本使用四 選擇器五 等待元素被加載六 元素交互操作七 其他八 項目練習一 介紹 selenium最初是一個自動化測試工具,而爬蟲中使用它主要是為了解決requests無法直接執行JavaScript代碼的問題selenium本質是通過驅動瀏覽器&#xff0c;完…

關閉iphone來電mac_如何在Mac和iPhone上關閉通用剪貼板切換(以及為什么要禁用此功能)

關閉iphone來電macIm about to tell you something that will shock you, and probably make you very angry. I hope you wont hate me for it. Here goes.我正要告訴您一些令您震驚的事情&#xff0c;并可能使您非常生氣。 我希望你不會為此而恨我。 開始。 If you are an i…

關于tomcat Post 數據參數的問題

2019獨角獸企業重金招聘Python工程師標準>>> POST請求本身并未限制傳入參數大小&#xff0c;是tomcat 容器設置了接收參數大小的限制。修改server.xml <Connector port"8080" protocol"HTTP/1.1" connectionTimeout"2000" red…

iOS:通信錄(完成)(18-01-18更)

1、讀取通信錄 1&#xff09;、9.0以前&#xff1a;AddressBook 2&#xff09;、9.0以后&#xff1a;Contacts 2、調用通信錄UI&#xff08;不弄&#xff09; 1&#xff09;、9.0以前&#xff1a;AddressBookUI 2&#xff09;、9.0以后&#xff1a;ContactsUI 3、參考 0、寫在前…

如何在React Native和Firebase中設置Google登錄

Google sign-in is a great login feature to offer to your apps users. It makes it easier for them to create an account and sign in. Google登錄是一項出色的登錄功能&#xff0c;可為您的應用程序用戶提供。 這使他們更容易創建帳戶并登錄。 And whats even better, F…

設計模式-發布訂閱模式

這段時間在看vue的雙向綁定原理&#xff0c;知道了vue的核心三大件&#xff1a;Observer, Complie, Watcher。 Observer用于監聽屬性的變化&#xff0c;如有變動就通知 Watcher。 Compile負責解析元素節點的指令&#xff0c;如v-if&#xff0c;v-bind之類, 進行數據和回調函數的…

杜教篩--51nod1239 歐拉函數之和

求$\sum_{i1}^{n}\varphi (i)$&#xff0c;$n\leqslant 1e10$。 這里先把杜教篩的一般套路貼一下&#xff1a; 要求$S(n)\sum_{i1}^{n}f(i)$&#xff0c;而現在有一數論函數$g(i)$&#xff0c;$g(i)$的前綴和很無腦&#xff0c;且$f$和$g$的狄利克雷卷積的前綴和很無腦&#xf…

【Android Studio安裝部署系列】目錄

概述 從剛開始使用Android Studio到現在&#xff0c;下面所有目錄下的操作&#xff0c;當時習慣性的把每一個整理成一個文檔&#xff08;其實就是簡單文字描述截圖&#xff09;&#xff1b;有些地方當時是一知半解&#xff0c;現在會稍微明白一些。正好趕上現在有時間。所以就想…

修改npm全局安裝模式的路徑

修改npm全局安裝模式的路徑 在正式寫此文章之前&#xff0c;我得說一點血淚史。 剛學nodeJS不久&#xff0c;很納悶為什么全局安裝的模塊在 node安裝目錄/node_modules‘ 中沒找到&#xff01;后來仔細看了下安裝成功后的信息&#xff0c;才發現原來是自動安裝在C盤了&#xff…

javascript創建類_如何使用JavaScript創建吹氣效果

javascript創建類Have you ever wondered how you can create a realistic air blowing effect with JavaScript? Like the one shown on the evening TV shows, where multiple balls are being mixed up in a sphere-like object by leveraging air pressure? If you want …

Bootstrap 4:如何使頂部固定的Navbar保持在容器中而不拉伸?

There are many ways to make a fixed navbar stay inside a parents div container. Well go over the most straightforward one here.有很多方法可以使固定的導航欄停留在父級的div容器中。 我們將在這里介紹最簡單的方法。 Imagine you have the following code, modified…

基于SpringBoot+Mybatis+Thymeleaf商品信息管理系統

github地址&#xff1a;github.com/zaiyunduan1…,如果對你有幫助&#xff0c;歡迎Star 主要用到的技術&#xff1a; 使用maven進行項目構建使用SpringbootMybatis搭建整個系統使用Thymeleaf模板技術實現頁面靜態化使用框架Bootstrap、JQuery開發前端界面使用MySQL和MongoDB分別…

在Mac上為自己手動編譯安裝一套PHP7的開發環境

首先你得去官網下載php7 beta1的版本 這里由于我是在mac上安裝&#xff0c;所以就去下載linux相關的版本&#xff0c;地址也直接附上了php7 beta1windows版的官方也有發布詳情猛戳&#xff1a;這里 解壓安裝包&#xff0c;進入源代碼目錄 tar -zxvf php-7.0.0beta1.tar.gz cd p…

卡特蘭數 HDU2067 HDU4165 HDU1134

題目鏈接&#xff1a;https://vjudge.net/problem/HDU-2067 小兔的棋盤 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 11800 Accepted Submission(s): 5952 Problem Description小兔的叔叔從外面旅游回來給她…