創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務(wù)器提供商,新人活動買多久送多久,劃算不套路!
目前成都創(chuàng)新互聯(lián)公司已為成百上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、網(wǎng)站運(yùn)營、企業(yè)網(wǎng)站設(shè)計、香洲網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。這篇文章給大家分享的是有關(guān)面試Python工程師必背的編碼題有哪些的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
第1題:列表[1,2,3,4,5],請使用map()函數(shù)輸出[1,4,9,16,25],并使用列表推導(dǎo)式提取出大于10的數(shù),最終輸出[16,25]。
map是python高階用法,字面意義是映射,它的作用就是把一個數(shù)據(jù)結(jié)構(gòu)映射成另外一種數(shù)據(jù)結(jié)構(gòu)。
map用法比較繞,最好是對基礎(chǔ)數(shù)據(jù)結(jié)構(gòu)很熟悉了再使用,比如列表,字典,序列化這些。
map的基本語法如下:
map(函數(shù), 序列1, 序列2, ...)
Python 2.x 返回列表。
Python 3.x 返回迭代器。
list = [1,2,3,4,5]def fn(x): return x ** 2res = map(fn,list) res = [i for i in res] print(res) res = [i for i in res if i > 10] print(res)
第2題:設(shè)計一個函數(shù)返回給定文件名的后綴?
考察字符串操作
rfind() # 右側(cè)字符出現(xiàn)的位置
注意下面的0 if ... else用法 第3題: 這兩個參數(shù)是什么意思:args,*kwargs?我們?yōu)槭裁匆褂盟鼈儯?/p> 如果我們不確定要往函數(shù)中傳入多少個參數(shù),或者我們想往函數(shù)中以 列表 和 元組 的形式傳參數(shù)時,那就使要用*args; 如果我們不知道要往函數(shù)中傳入多少個關(guān)鍵詞參數(shù),或者想傳入 字典 的值作為關(guān)鍵詞參數(shù)時,那就要使用**kwargs。 args和kwargs這兩個標(biāo)識符是約定俗成的用法,你當(dāng)然還可以用tom和*jarry,但是這樣顯的不專業(yè)。 下面是具體的示例: 案例來源互聯(lián)網(wǎng)搜索,都書寫一遍即可掌握 第4題: 求出 0~n 的所有正整數(shù)中數(shù)字k(0~9)出現(xiàn)的次數(shù)。編程語言不限,Python優(yōu)先。 舉例 例如:k=1,n=12,那么 1 在 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]一共出現(xiàn)5次[1,10,11,12] 輸入:k=1,n=12 輸出:5 解答思路: 統(tǒng)計數(shù)字 1 在 [1,10,11,12]出現(xiàn)的次數(shù)這非常像Python中統(tǒng)計字符串a(chǎn)在字符串b中出現(xiàn)的次數(shù): b.count(a) 所以我們將把數(shù)字轉(zhuǎn)為字符串來做統(tǒng)計。 第5題: 如何在python中使用三元運(yùn)算符? python中沒有其他語言中的三元表達(dá)式,不過有類似的實現(xiàn)方法 句法: 三元操作符語法如下, [on_true] if [expression] else [on_false] 例: 如果x 感謝各位的閱讀!關(guān)于面試Python工程師必背的編碼題有哪些就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!def get_suffix(filename, has_dot=False):
"""
獲取文件名的后綴名
:param filename: 文件名
:param has_dot: 返回的后綴名是否需要帶點
:return: 文件的后綴名
"""
pos = filename.rfind('.')
if 0 < pos < len(filename) - 1:
index = pos if has_dot else pos + 1
return filename[index:]
else:
return ''
def f(*args,**kwargs):
print(args, kwargs)
l = [1,2,3]
t = (4,5,6)
d = {'a':7,'b':8,'c':9}
f()
f(1,2,3) # (1, 2, 3) {}
f(1,2,3,"groovy") # (1, 2, 3, 'groovy') {}
f(a=1,b=2,c=3) # () {'a': 1, 'c': 3, 'b': 2}
f(a=1,b=2,c=3,zzz="hi") # () {'a': 1, 'c': 3, 'b': 2, 'zzz': 'hi'}
f(1,2,3,a=1,b=2,c=3) # (1, 2, 3) {'a': 1, 'c': 3, 'b': 2}
f(*l,**d) # (1, 2, 3) {'a': 7, 'c': 9, 'b': 8}
f(*t,**d) # (4, 5, 6) {'a': 7, 'c': 9, 'b': 8}
f(1,2,*t) # (1, 2, 4, 5, 6) {}
f(q="winning",**d) # () {'a': 7, 'q': 'winning', 'c': 9, 'b': 8}
f(1,2,*t,q="winning",**d) # (1, 2, 4, 5, 6) {'a': 7, 'q': 'winning', 'c': 9, 'b': 8}
def f2(arg1,arg2,*args,**kwargs):
print(arg1,arg2, args, kwargs)
f2(1,2,3) # 1 2 (3,) {}
f2(1,2,3,"groovy") # 1 2 (3, 'groovy') {}
f2(arg1=1,arg2=2,c=3) # 1 2 () {'c': 3}
f2(arg1=1,arg2=2,c=3,zzz="hi") # 1 2 () {'c': 3, 'zzz': 'hi'}
f2(1,2,3,a=1,b=2,c=3) # 1 2 (3,) {'a': 1, 'c': 3, 'b': 2}
f2(*l,**d) # 1 2 (3,) {'a': 7, 'c': 9, 'b': 8}
f2(*t,**d) # 4 5 (6,) {'a': 7, 'c': 9, 'b': 8}
f2(1,2,*t) # 1 2 (4, 5, 6) {}
f2(1,1,q="winning",**d) # 1 1 () {'a': 7, 'q': 'winning', 'c': 9, 'b': 8}
f2(1,2,*t,q="winning",**d) # 1 2 (4, 5, 6) {'a': 7, 'q': 'winning', 'c': 9, 'b': 8}
def digit_count(k,n):
listn = []
count = 0
for i in range(0,n+1):
count += str(i).count(str(k))
if str(k) in str(i):
listn.append(str(i))
return count,listn
c,ls = digit_count(1,12)
print(c,ls)
x,y = 15,22
big = x if x < y else y
本文題目:面試Python工程師必背的編碼題有哪些-創(chuàng)新互聯(lián)
文章路徑:http://weahome.cn/article/csdeie.html