ARTS 第三周

ARTS是什么?
Algorithm:每周至少做一個(gè)leetcode的算法題;
Review:閱讀并點(diǎn)評(píng)至少一篇英文技術(shù)文章;
Tip/Techni:學(xué)習(xí)至少一個(gè)技術(shù)技巧;
Share:分享一篇有觀點(diǎn)和思考的技術(shù)文章。

一、Algorithm

Question: 636 Exclusive Time of Functions (Medium)
給定N個(gè)運(yùn)行在單CPU的函數(shù)的運(yùn)行時(shí)間log,找到每個(gè)函數(shù)的實(shí)際運(yùn)行時(shí)間。
每個(gè)函數(shù)都有唯一的ID,編號(hào)為0到n-1,函數(shù)可以被遞歸的調(diào)用。
log為字符串,格式如下:function_id:start_or_end:timestamp。比如“0:start:0” 表示函數(shù)0 從時(shí)間0開始運(yùn)行。“0:end:2”表示函數(shù)0在時(shí)間2結(jié)束。

#input and output example 
input:
n = 2
logs = 
["0:start:0",
 "1:start:2",
 "1:end:5",
 "0:end:6"]
Output:[3, 4]

Solution:
函數(shù)的調(diào)用,本身就是用stack來實(shí)現(xiàn)的。如果用堆來實(shí)現(xiàn),首先從list[0]一次進(jìn)行入棧,棧中保存的是進(jìn)程編號(hào),如果動(dòng)作是start,且棧中不為空,那么直接入棧,且推的最上面一個(gè)進(jìn)程運(yùn)行時(shí)間為之前現(xiàn)在的時(shí)間減去上一次的時(shí)間。如果動(dòng)作是stop,那么直接棧中最上面一個(gè)進(jìn)程的運(yùn)行時(shí)間為現(xiàn)在的時(shí)間減去上一次時(shí)間+1,然后出棧。

比如上面的case:
0:start:0 ans = [0,0] stack.top=0,curTime=0
1:start:2 ans = [2-0,0] stack.top=1,curTime=2
1:end:5 ans= [2,4] stack.top=0,curTime=6
0:end:6 ans=[6-6+1+2,4] stack=None, curTime=7
Output=[3,4]

class Solution:
    def exclusiveTime(self, n: int, logs: List[str]) -> List[int]:
        ans = [0]*n
        s = []
        curTime = 0
        
        for i in range(len(logs)):
            curLog = logs[i].split(":")
            curId = int(curLog[0])
            status = curLog[1]
            nextTime = int(curLog[2])
            
            if (status == "start"):
                if (s):
                    ans[s[-1]] += nextTime - curTime
                s.append(curId)
                curTime = nextTime
            else:
                ans[s[-1]] += nextTime - curTime + 1
                s.pop()
                curTime = nextTime + 1
            
        return ans

Runtime: 76 ms, faster than 23.33% of Python3 online submissions for Exclusive Time of Functions.
Memory Usage: 13.1 MB, less than 6.90% of Python3 online submissions for Exclusive Time of Functions.
這是最終的結(jié)果,內(nèi)存和運(yùn)行時(shí)間都不是很理想。理論運(yùn)行時(shí)間為O(N),空間為O(N)。但是看了提交的運(yùn)行時(shí)間比較短的結(jié)果,代碼差不多,很迷。

二、Review:
Genuinely useful career resources for self-taught developers

自學(xué)的開發(fā)者的有用的資源推薦

  1. 社區(qū)
  1. 寫代碼并構(gòu)建自己的作品
  1. 咨詢并參與到wiki建設(shè)中
  1. 通過不同的途徑找到工作機(jī)會(huì)

三、Tips
在使用vim的過程中,因?yàn)橛锌旖萱I,所以vim能比其他大部分的編輯器都要高效。比如復(fù)制,粘貼,光標(biāo)快速移動(dòng),行內(nèi)移動(dòng)等等。

而Shell也是一樣有快捷鍵的。

  • ctrl+r:之后再輸入命令,能夠快速匹配歷史命令
  • clear:清理屏幕
  • 上箭頭或者ctrl+p:上一條命令
  • 下箭頭或者ctrl+n:下一條命令
  • !!:重復(fù)上一條命令,其他的命令諸如!$,!^,!N,!str,這類不常用的就列了。
  • ctrl+h:向前刪除一個(gè)字符,等同于delete
  • ctrl+d:向后刪除一個(gè)字符,等同mac fn+delete
  • ctrl+w:刪除光標(biāo)前一個(gè)單詞
  • ctrl+u: 刪除光標(biāo)前面所有內(nèi)容
  • ctrl+k:刪除光標(biāo)后面所有內(nèi)容
  • ctrl+a: 移動(dòng)光標(biāo)到開始(a為第一個(gè)字母)
  • ctrl+3: 移動(dòng)光標(biāo)到結(jié)束(end)
  • ctrl+f: 光標(biāo)前移一次
  • ctrl+b:光標(biāo)后移一次
  • alt+f:光標(biāo)前移一個(gè)單詞
  • alt+b:光標(biāo)后移一個(gè)單詞
  • ctrl+xx:行首到當(dāng)前光標(biāo)替換

四、Share
我的抖音賬號(hào)只是用手機(jī)號(hào)碼登錄的,沒有用微信登錄,也沒有打開通訊錄權(quán)限。但是在可能認(rèn)識(shí)的人中,給不推薦了不少微信好友。一直很感興趣抖音、多閃等是如何推薦微信好友給用戶的,分別在keso和可能吧公眾號(hào)都看到了抖音會(huì)主動(dòng)抓取用戶的關(guān)系鏈。以下是根據(jù)多少搜索的信息總結(jié),微信關(guān)系鏈獲取的方式:

假如A分享了一個(gè)鏈接到微信,分享的鏈接中帶有A的標(biāo)識(shí);如果其他的人B授權(quán)微信登錄并通過微信瀏覽器訪問了,那么抖音會(huì)認(rèn)為B和A是相關(guān)的,可能是群友,也可能是二度關(guān)系。如果A和B這類的交互比較多,大概率就是朋友了,如果能收集到足夠多的數(shù)據(jù),就能計(jì)算用戶大多數(shù)的關(guān)系鏈了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容