天天看點

筆試 - 高德軟體有限公司python試題 及 答案

本文位址: http://blog.csdn.net/caroline_wendy/article/details/25230835

by spike 2014.5.7

本題目僅供學術交流, 嚴禁用于其他目的, 答案僅供參考.

1. 在python中, list, tuple, dict, set有什麼差別, 主要應用在什麼樣的場景?

解答:

定義:

list: 連結清單, 有序的項目, 通過索引進行查找, 使用方括号"[]";

tuple: 元組, 元組将多樣的對象集合到一起, 不能修改, 通過索引進行查找, 使用括号"()";

dict: 字典, 字典是一組鍵(key)和值(value)的組合, 通過鍵(key)進行查找, 沒有順序, 使用大括号"{}";

set: 集合,無序, 元素隻出現一次, 自動去重, 使用"set([])";

應用場景: 

list, 簡單的資料集合, 可以使用索引; 

tuple, 把一些資料當做一個整體去使用, 不能修改;

dict, 使用鍵值和值進行關聯的資料;

set, 資料隻出現一次, 隻關心資料是否出現, 不關心其位置;

代碼:

2. 靜态函數, 類函數, 成員函數的差別?

靜态函數(@staticmethod): 即靜态方法,主要處理與這個類的邏輯關聯;

類函數(@classmethod): 即類方法, 更關注于從類中調用方法, 而不是在執行個體中調用方法, 可以用作方法重載, 傳入參數cls;

成員函數: 執行個體的方法, 隻能通過執行個體進行調用;

具體應用:

日期的方法, 可以通過執行個體化(__init__)進行資料輸出, 傳入參數self;

可以通過類的方法(@classmethod)進行資料轉換, 傳入參數cls;

可以通過靜态方法(@staticmethod)進行資料驗證;

3. a=1, b=2, 不用中間變量交換a和b的值

兩種形式:

加法或異或

4. 寫一個函數, 輸入一個字元串, 傳回倒序排列的結果: 如: string_reverse(‘abcdef’), 傳回: ‘fedcba’

(請采用多種方法實作, 并對實作方法進行比較)

5種方法的比較:

1. 簡單的步長為-1, 即字元串的翻轉;

2. 交換前後字母的位置;

3. 遞歸的方式, 每次輸出一個字元;

4. 雙端隊列, 使用extendleft()函數;

5. 使用for循環, 從左至右輸出;

5. 請用自己的算法, 按升序合并如下兩個list, 并去除重複的元素:

list1 = [2, 3, 8, 4, 9, 5, 6]

list2 = [5, 6, 10, 17, 11, 2]

合并連結清單, 遞歸的快速排序, 去重連結;

注: 如果使用set方法, list(set(list1 + list2)), 即可.

6. 請寫出列印結果

x = [0, 1]

i = 0

i, x[i] = 1, 2

print(x)

列印結果: [0, 2], python可以使用連續指派, 從左至右.

g = lambda x, y=2, z : x + y**z

g(1, z=10) = ?

列印結果: 異常, 形參表末尾才可以有預設參數, z需要提供預設參數.

7. 說一下以下代碼片段存在的問題

解答: 

1. 警告: object是python新形式(new style)的一個基礎類, 不應該被重新定義;

2. 警告: 類方法(classmethod)是類所擁有的方法, 傳入的參數應該是cls, 而不是self;

3. 錯誤: python沒有new關鍵字, 如需修改new, 如單例模式, 可以重寫(override)__new__;

4. 錯誤: @property, 表示屬性, 不是方法, 則不需要加括号”()”, 直接調用object.man, 即可;

5. 錯誤: 如果想使用基類的成員, 則需要初始化基類, 如dummyclass.__init__(self), 即可;

6. 額外: 類名盡量使用大寫.

8. 介紹一下python的異常處理機制和自己開發過程中的體會

python的異常處理機制:

try: 嘗試抛出異常;

raise: 引發異常;

except: 處理異常;

finally: 是否發生異常都需要做的事情;

建立新的異常類型, 需要繼承exception類, 可以定義類的屬性, 便于處理異常;

開發體會:

異常主要處理讀取檔案, 也可以使用with的方法讀取檔案; 還可以用于網絡連接配接, 異常可以包含大量的錯誤資訊, 進行錯誤處理.

筆試 - 高德軟體有限公司python試題 及 答案