周三面試Python開發,這幾道Python面試題差點答錯,Python面試題No7

来源:https://www.cnblogs.com/happymeng/archive/2019/05/14/10860290.html
-Advertisement-
Play Games

第1題:閱讀下麵的代碼,默讀出A0,A1至An的最終值。 默讀代碼類的題目,相對來說是比較簡單的。重點去研究列表解析,之後你就可以輕鬆的回答這些問題嘍~ 第2題:如何提高python的運行效率? 1. 數據結構一定要選對 能用字典就不用列表:字典在索引查找和排序方面遠遠高於列表。 2. 多用pyth ...


第1題:閱讀下麵的代碼,默讀出A0,A1至An的最終值。

A0 = dict(zip(('a','b','c','d','e'),(1,2,3,4,5)))
A1 = range(10)
A2 = [i for i in A1 if i in A0]
A3 = [A0[s] for s in A0]
A4 = [i for i in A1 if i in A3]
A5 = {i:i*i for i in A1}
A6 = [[i,i*i] for i in A1]

默讀代碼類的題目,相對來說是比較簡單的。重點去研究列表解析,之後你就可以輕鬆的回答這些問題嘍~

A0 = {'a': 1, 'c': 3, 'b': 2, 'e': 5, 'd': 4}
A1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
A2 = []
A3 = [1, 3, 2, 5, 4]
A4 = [1, 2, 3, 4, 5]
A5 = {0: 0, 1: 1, 2: 4, 3: 9, 4: 16, 5: 25, 6: 36, 7: 49, 8: 64, 9: 81}
A6 = [[0, 0], [1, 1], [2, 4], [3, 9], [4, 16], [5, 25], [6, 36], [7, 49], [8, 64], [9, 81]]

第2題:如何提高python的運行效率?

  1. 數據結構一定要選對
    能用字典就不用列表:字典在索引查找和排序方面遠遠高於列表。
  2. 多用python中封裝好的模塊庫
    關鍵代碼使用外部功能包(Cython,pylnlne,pypy,pyrex)
  3. 使用生成器
  4. 針對迴圈的優化
    儘量避免在迴圈中訪問變數的屬性
  5. 使用較新的Python版本

第3題: Python字典有什麼特點,從字典中取值,時間複雜度是多少?

dict(中文叫字典)是另一種可變容器模型,且可存儲任意類型對象。
字典的每個鍵值(key=>value)對用冒號(:)分割,每個對之間用逗號(,)分割,整個字典包括在花括弧{}
字典的特性

  1. 查找速度快
    無論dict有10個元素還是10萬個元素,查找速度都一樣。而list的查找速度隨著元素增加而逐漸下降。
    不過dict的查找速度快不是沒有代價的,dict的缺點是占用記憶體大,還會浪費很多內容,list正好相反,占用記憶體小,但是查找速度慢。
  2. 字典值可以沒有限制地取任何python對象,既可以是標準的對象,也可以是用戶定義的,但鍵不行。
    不允許同一個鍵出現兩次。
    鍵必須不可變,所以可以用數字,字元串或元組充當,所以用列表就不行。
  3. dict的第二個特點就是存儲的key-value序對是沒有順序的!這和list不一樣。

從字典中取值,時間複雜度是多少
O(1),字典是hash table實現

第4題: 多線程、多進程?

  1. 線程
    線程是操作系統能夠進行運算調度的==最小單位==。它被包含在進程之中,是進程中的實際運作單位。
    一條線程指的是進程中一個單一順序的控制流,一個進程中可以併發多個線程,每條線程並行執行不同的任務。一個線程是一個execution context(執行上下文),即一個cpu執行時所需要的一串指令。

  2. 進程
    一個程式的==執行實例==就是一個進程。每一個進程提供執行程式所需的所有資源。(進程本質上是資源的集合)
    一個進程有一個虛擬的地址空間、可執行的代碼、操作系統的介面、安全的上下文(記錄啟動該進程的用戶和許可權等等)、唯一的進程ID、環境變數、優先順序類、最小和最大的工作空間(記憶體空間),還要有==至少一個線程==。
    每一個進程啟動時都會最先產生一個線程,即主線程 然後主線程會再創建其他的子線程。

進程與線程區別

轉載自互聯網,總結的挺好的,有益!
深入的理解看這篇博客就可以了:https://www.cnblogs.com/whatisfantasy/p/6440585.html

  1. 同一個進程中的線程共用同一記憶體空間,但是進程之間是獨立的。
  2. 同一個進程中的所有線程的數據是共用的(進程通訊),進程之間的數據是獨立的。
  3. 對主線程的修改可能會影響其他線程的行為,但是父進程的修改(除了刪除以外)不會影響其他子進程。
  4. 線程是一個上下文的執行指令,而進程則是與運算相關的一簇資源。
  5. 同一個進程的線程之間可以直接通信,但是進程之間的交流需要藉助中間代理來實現。
  6. 創建新的線程很容易,但是創建新的進程需要對父進程做一次複製。
  7. 一個線程可以操作同一進程的其他線程,但是進程只能操作其子進程。
  8. 線程啟動速度快,進程啟動速度慢(但是兩者運行速度沒有可比性)。

第5題: 請儘可能列舉python列表的成員方法,並給出以下列表操作的答案:

  1. a=[1, 2, 3, 4, 5], a[::2]=?, a[-2:] = ?
a[::2] = [1, 3, 5], a[-2:] = [4, 5]
  1. 一行代碼實現對列表a中的偶數位置的元素進行加3後求和?
from functools import reduce
a = [1, 2, 3, 4, 5]
print(reduce(lambda x, y: x+y, [(x+3*((a.index(x)+1)%2)) for x in a])) # a中元素均不相同
# 或
print(reduce(lambda x, y: x+y, [a[x]+(x+1)%2*3 for x in range(0, 5)])) # 只適用於a中元素有5個情況
  1. 將列表a的元素順序打亂,再對a進行排序得到列表b,然後把a和b按元素順序構造一個字典d。
from random import shuffle
a = [1, 2, 3, 4, 5]
# 打亂列表a的元素順序
shuffle(a)
# 對a進行排序得到列表b
b = sorted(a, reverse=True)
# zip 並行迭代,將兩個序列“壓縮”到一起,然後返回一個元組列表,最後,轉化為字典類型。
d = dict(zip(a, b))
print(d)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 自己從作者官方網站上(http://www.cslanet.com/)下載的免費版.PDF文檔,又使用有道付款翻譯的,供大家下載學習,文檔中是對CSLA.NET4.9版本的介紹。 下載鏈接:http://www.oaflow.cn/CSLA 2019 - 01 Overview r0-1.zip 翻 ...
  • 用來創建獨一無二的,是能有一個實例的對象的入場券。告訴你一個好消息,單例模式的類圖可以說是所有模式的類圖中最簡單的,事實上,它的類圖上只有一個類!但是,可不要興奮過頭,儘管從類設計的視角來說很簡單,但是實現上還是會遇到相當多的波折。所以,系好安全帶,出發了! <! more 介紹 定義 單例模式(S ...
  • 系統的講解 - SSO單點登錄 原文鏈接:mp.weixin.qq.com 概念 SSO 英文全稱 Single Sign On,單點登錄。 在多個應用系統中,只需要登錄一次,就可以訪問其他相互信任的應用系統。 比如:淘寶網(www.taobao.com),天貓網(www.tmall.com),聚劃 ...
  • 後端架構師技術圖譜 原文鏈接:github.com 最後更新於20180502 數據結構 隊列 集合 鏈表、數組 字典、關聯數組 棧 樹 二叉樹 完全二叉樹 平衡二叉樹 二叉查找樹(BST) 紅黑樹 B-,B+,B*樹 LSM 樹 BitSet 常用演算法 排序、查找演算法 選擇排序 冒泡排序 插入排序 ...
  • 對於配置中心我們先拋出問號三連,什麼是配置中心?為什麼要用配置中心?配置中心怎麼用? 筆者說說自己理解的配置中心,個人觀點的十六字 消息存儲 消息推送 環境隔離 灰度發佈 今天我們先來看Apollo配置中心怎麼用,小伙伴可能會說,這不是很簡單嘛,no,我們同時要來揭開配置保存的實現原理。 apoll ...
  • 在本次學習過程中,我們把封裝帶到一個全新的境界:把方法調用(method invocation)封裝起來 。沒錯,通過封裝方法調用,我們可以把運算塊包裝成形。 所以調用此運算的對象不需要關心事情是如何進行的,只要知道如何使用包裝成形的方法來完成它就可以。通過封裝方法調用,也可以做一些很聰明的事情,例 ...
  • 概述 基於串口的SD_card系統1, 掃描文件;2, 新建文件;3, 刪除文件;4, 寫入文件;5, 讀取文件。 整個文件系統的串口通信方式都是ASC通信方式。 文件系統分為簡單實用方式和專業使用方式,簡單使用方式只需要普通的串口調試助手就可以完成。專業使用方式需要專用的調試上位機。簡單模式/專業 ...
  • 背景 很多人心裡是想一直做技術的,但是擔心隨著年紀增加,會造成在技術方面的競爭力不足。加上迫於經驗人士的壓力,就在糾結要不要轉管理崗。不是什麼權威意見,僅僅談談個人看法。 個人觀點:做自己想做的事。 優劣勢 技術和管理兩個路線各有優劣勢。用SWOT分析來展現兩個維度的關係。 如果有朋友對到底是走哪個 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...