2019年8月11日 星期日

[LeetCode] 1108. Defanging an IP Address 解題思路 (Easy):快速秒殺解決!



給一組有效的 IPv4 的 IP 地址,返回該 IP 地址的默認版本。
然後這個違規的 IP 地址會將句號 "." 用 "[.]" 取代。




LeetCode eetCode 題目連結


https://leetcode.com/problems/defanging-an-ip-address/

題目

1108. Defanging an IP Address
Easy
Given a valid (IPv4) IP address, return a defanged version of that IP address.
defanged IP address replaces every period "." with "[.]".

Example 1:
Input: address = "1.1.1.1"
Output: "1[.]1[.]1[.]1"
Example 2:
Input: address = "255.100.50.0"
Output: "255[.]100[.]50[.]0"

Constraints:
  • The given address is a valid IPv4 address.

Accept 作法


我一開始看到這題的時候選擇用 replace 來解題,果然就秒解了!程式設計師要選擇最快最有效率的方式解題是不是?

Runtime: 188 ms
Memory: 36.6 mb

Kotlin
  1. class Solution {
  2. fun defangIPaddr(address: String): String {
  3. val result = address.replace(".","[.]")
  4. return result
  5. }
  6. }


後來選擇還是不要套現成的 API 好了。就有第二種作法。

Runtime: 140 ms
Memory: 31.6 mb

Kotlin
  1. class Solution {
  2. fun defangIPaddr(address: String): String {
  3. var newAddress = "";
  4. for(i in 0..address.length-1){
  5. if(address.get(i).toString().equals(".")){
  6. newAddress = newAddress+"["+ address.get(i)+"]"
  7. }else{
  8. newAddress = newAddress+address.get(i)
  9. }
  10. }
  11. return newAddress
  12.  
  13. }
  14. }

這邊 Kotlin 跟 Java 的 String 不一樣的是它拿每一個字元直接用 get 不是 charAt , get 回來轉型成 String 才能用 equals 來比對。

還有第三種作法,String 最常被討論如果有大量字串處理時有效能問題,用 StringBuilder 比較好,於是這題就拿來實驗看看,但結果時間一樣,我想是因為本身字串長度就滿短的,所以沒差。

Runtime: 140 ms
Memory: 31.6 mb


Kotlin
  1. class Solution {
  2. fun defangIPaddr(address: String): String {
  3. var newAddress = StringBuilder();
  4. for(i in 0..address.length-1){
  5. if(address.get(i).toString().equals(".")){
  6. newAddress.append("["+ address.get(i)+"]")
  7. }else{
  8. newAddress.append(address.get(i))
  9. }
  10. }
  11. return newAddress.toString()
  12.  
  13. }
  14. }


更多 LeetCode 相關資源


複習程式面試書籍


除了 LeetCode 練習外,我也入手了這本,題庫來自真正的面試,並非摘自教科書。它們反映出頂尖公司真正會出的題目,你可以藉此做好充分準備

需要的話可以看看,寫得很仔細。



書名:提升程式設計師的面試力:189道面試題目與解答




相關 LeetCode文章一律會放在 程式解題 標籤分類,歡迎持續追蹤。


2 則留言:

  1. It come to be an appealing part of a blog whilst author uses oblique speech even as writing a blog. It suggests your creative thoughts as well as make your written essay specific from others. kickass proxy

    回覆刪除
  2. written content. I added new knowledge to my database for essay writing skill. text to image

    回覆刪除