python解题软件哪个好_笔试 - 高德软件有限公司python问题 和 答案
高德軟件有限公司python問(wèn)題 和 答案
本文地址: http://blog.csdn.net/caroline_wendy/article/details/25230835
by Spike 2014.5.7
本題目?jī)H供學(xué)術(shù)交流, 嚴(yán)禁用于其它目的, 答案僅供參考.
1. 在python中, list, tuple, dict, set有什么差別, 主要應(yīng)用在什么樣的場(chǎng)景?
解答:
定義:
list:鏈表, 有序的項(xiàng)目, 通過(guò)索引進(jìn)行查找, 使用方括號(hào)"[]";
tuple:元組, 元組將多樣的對(duì)象集合到一起, 不能改動(dòng), 通過(guò)索引進(jìn)行查找, 使用括號(hào)"()";
dict:字典, 字典是一組鍵(key)和值(value)的組合, 通過(guò)鍵(key)進(jìn)行查找, 沒(méi)有順序, 使用大括號(hào)"{}";
set:集合,無(wú)序, 元素僅僅出現(xiàn)一次, 自己主動(dòng)去重, 使用"set([])";
應(yīng)用場(chǎng)景:
list, 簡(jiǎn)單的數(shù)據(jù)集合, 能夠使用索引;
tuple, 把一些數(shù)據(jù)當(dāng)做一個(gè)總體去使用, 不能改動(dòng);
dict, 使用鍵值和值進(jìn)行關(guān)聯(lián)的數(shù)據(jù);
set, 數(shù)據(jù)僅僅出現(xiàn)一次, 僅僅關(guān)心數(shù)據(jù)是否出現(xiàn), 不關(guān)心其位置;
代碼:
mylist = [1, 2, 3, 4, 'Oh']
mytuple = (1, 2, 'Hello', (4, 5))
mydict = {'Wang' : 1, 'Hu' : 2, 'Liu' : 4}
myset = set(['Wang', 'Hu', 'Liu', 4, 'Wang'])
2. 靜態(tài)函數(shù), 類函數(shù), 成員函數(shù)的差別?
解答:
定義:
靜態(tài)函數(shù)(@staticmethod): 即靜態(tài)方法,主要處理與這個(gè)類的邏輯關(guān)聯(lián);
類函數(shù)(@classmethod): 即類方法, 更關(guān)注于從類中調(diào)用方法, 而不是在實(shí)例中調(diào)用方法, 能夠用作方法重載, 傳入?yún)?shù)cls;
成員函數(shù): 實(shí)例的方法, 僅僅能通過(guò)實(shí)例進(jìn)行調(diào)用;
詳細(xì)應(yīng)用:
日期的方法, 能夠通過(guò)實(shí)例化(__init__)進(jìn)行數(shù)據(jù)輸出, 傳入?yún)?shù)self;
能夠通過(guò)類的方法(@classmethod)進(jìn)行數(shù)據(jù)轉(zhuǎn)換, 傳入?yún)?shù)cls;
能夠通過(guò)靜態(tài)方法(@staticmethod)進(jìn)行數(shù)據(jù)驗(yàn)證;
代碼:
# -*- coding: utf-8 -*-
#eclipse pydev, python 3.3
#by C.L.Wang
class Date(object):
day = 0
month = 0
year = 0
def __init__(self, day=0, month=0, year=0):
self.day = day
self.month = month
self.year = year
def display(self):
return "{0}*{1}*{2}".format(self.day, self.month, self.year)
@classmethod
def from_string(cls, date_as_string):
day, month, year = map(int, date_as_string.split('-'))
date1 = cls(day, month, year)
return date1
@staticmethod
def is_date_valid(date_as_string):
day, month, year = map(int, date_as_string.split('-'))
return day <= 31 and month <= 12 and year <= 3999
date1 = Date('12', '11', '2014')
date2 = Date.from_string('11-13-2014')
print(date1.display())
print(date2.display())
print(date2.is_date_valid('11-13-2014'))
print(Date.is_date_valid('11-13-2014'))
3. a=1, b=2, 不用中間變量交換a和b的值
解答:
兩種形式: 加法或異或
代碼:
a = 1
b = 2
a = a + b
b = a - b
a = a - b
print ('a = {0}, b = {1}'.format(a, b))
a = a ^ b
b = a ^ b
a = a ^ b
print ('a = {0}, b = {1}'.format(a, b))
4. 寫一個(gè)函數(shù), 輸入一個(gè)字符串, 返回倒序排列的結(jié)果: 如: string_reverse(‘a(chǎn)bcdef’), 返回: ‘fedcba’
(請(qǐng)採(cǎi)用多種方法實(shí)現(xiàn), 并對(duì)實(shí)現(xiàn)方法進(jìn)行比較)
解答:
5種方法的比較:
1. 簡(jiǎn)單的步長(zhǎng)為-1, 即字符串的翻轉(zhuǎn);
2. 交換前后字母的位置;
3. 遞歸的方式, 每次輸出一個(gè)字符;
4. 雙端隊(duì)列, 使用extendleft()函數(shù);
5. 使用for循環(huán), 從左至右輸出;
代碼:
string = 'abcdef'
def string_reverse1(string):
return string[::-1]
def string_reverse2(string):
t = list(string)
l = len(t)
for i,j in zip(range(l-1, 0, -1), range(l//2)):
t[i], t[j] = t[j], t[i]
return "".join(t)
def string_reverse3(string):
if len(string) <= 1:
return string
return string_reverse3(string[1:]) + string[0]
from collections import deque
def string_reverse4(string):
d = deque()
d.extendleft(string)
return ''.join(d)
def string_reverse5(string):
#return ''.join(string[len(string) - i] for i in range(1, len(string)+1))
return ''.join(string[i] for i in range(len(string)-1, -1, -1))
print(string_reverse1(string))
print(string_reverse2(string))
print(string_reverse3(string))
print(string_reverse4(string))
print(string_reverse5(string))
5. 請(qǐng)用自己的算法, 按升序合并例如以下兩個(gè)list, 并去除反復(fù)的元素:
list1 = [2, 3, 8, 4, 9, 5, 6]
list2 = [5, 6, 10, 17, 11, 2]
解答:
合并鏈表, 遞歸的高速排序, 去重鏈接;
代碼:
import random
list1 = [2, 3, 8, 4, 9, 5, 6]
list2 = [5, 6, 10, 17, 11, 2]
def qsort(L):
if len(L)<2: return L
pivot_element = random.choice(L)
small = [i for i in L if i< pivot_element]
large = [i for i in L if i> pivot_element]
return qsort(small) + [pivot_element] + qsort(large)
def merge(list1, list2):
return qsort(list1 + list2)
print(merge(list1, list2))
注: 假設(shè)使用set方法, list(set(list1 + list2)), 就可以.
6. 請(qǐng)寫出打印結(jié)果
x = [0, 1]
i = 0
i, x[i] = 1, 2
print(x)
打印結(jié)果:[0, 2], python能夠使用連續(xù)賦值, 從左至右.
g = lambda x, y=2, z : x + y**z
g(1, z=10) = ?
打印結(jié)果:異常, 形參表末尾才干夠有默認(rèn)參數(shù), z須要提供默認(rèn)參數(shù).
7. 說(shuō)一下下面代碼片段存在的問(wèn)題
from amodule import * # amodule is an exist module
class dummyclass(object):
def __init__(self):
self.is_d = True
pass
class childdummyclass(dummyclass):
def __init__(self, isman):
self.isman = isman
@classmethod
def can_speak(self): return True
@property
def man(self): return self.isman
if __name__ == "__main__":
object = new childdummyclass(True)
print object.can_speak()
print object.man()
print object.is_d解答:
1. 警告: object是python新形式(new style)的一個(gè)基礎(chǔ)類, 不應(yīng)該被又一次定義;
2. 警告: 類方法(classmethod)是類所擁有的方法, 傳入的參數(shù)應(yīng)該是cls, 而不是self;
3. 錯(cuò)誤: Python沒(méi)有newkeyword, 如需改動(dòng)new, 如單例模式, 能夠重寫(override)__new__;
4. 錯(cuò)誤: @property, 表示屬性, 不是方法, 則不須要加括號(hào)”()”, 直接調(diào)用object.man, 就可以;
5. 錯(cuò)誤: 假設(shè)想使用基類的成員, 則須要初始化基類, 如dummyclass.__init__(self), 就可以;
6. 額外: 類名盡量使用大寫.
代碼:
class dummyclass(object):
def __init__(self):
self.is_d = True
pass
class childdummyclass(dummyclass):
def __init__(self, isman):
dummyclass.__init__(self) #__init__
self.isman = isman
@classmethod
def can_speak(cls): return True #cls
@property
def man(self): return self.isman
if __name__ == "__main__":
o = childdummyclass(True) #new, object
print o.can_speak()
print o.man #property
print o.is_d
8. 介紹一下python的異常處理機(jī)制和自己開(kāi)發(fā)過(guò)程中的體會(huì)
解答:
Python的異常處理機(jī)制:
try: 嘗試拋出異常;
raise: 引發(fā)異常;
except: 處理異常;
finally: 是否發(fā)生異常都須要做的事情;
創(chuàng)建新的異常類型, 須要繼承Exception類, 能夠定義類的屬性, 便于處理異常;
開(kāi)發(fā)體會(huì):
異常主要處理讀取文件, 也能夠使用with的方法讀取文件; 還能夠用于網(wǎng)絡(luò)連接, 異常能夠包括大量的錯(cuò)誤信息, 進(jìn)行錯(cuò)誤處理.
代碼:
class ShortInputException(Exception):
def __init__(self, length, atleast):
Exception.__init__(self)
self.length = length
self.atleast = atleast
while True:
try:
text = raw_input('Enter somthing-->')
if len(text) < 3:
raise ShortInputException(len(text), 3)
except EOFError:
print('Why did you do an EOF on me')
except ShortInputException as ex:
print('ShortInputException The input was {0} long, \
excepted at least {1}. '.format(ex.length, ex.atleast))
else:
print('No exception was raised. ')
finally:
print('Over')
總結(jié)
以上是生活随笔為你收集整理的python解题软件哪个好_笔试 - 高德软件有限公司python问题 和 答案的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: kafka创建topic_一网打尽Kaf
- 下一篇: python程序结构有哪几种_Pytho