點(diǎn)評(píng):這個(gè)題目看似簡(jiǎn)單,但實(shí)際上還是比較考察面試者的功底。
因?yàn)镻ython內(nèi)置的max函數(shù)既可以傳入可迭代對(duì)象找出最大,又可以傳入兩個(gè)或多個(gè)參數(shù)找出最大;
最為關(guān)鍵的是還可以通過(guò)命名關(guān)鍵字參數(shù)key來(lái)指定一個(gè)用于元素比較的函數(shù),還可以通過(guò)default命名關(guān)鍵字參數(shù)來(lái)指定當(dāng)可迭代對(duì)象為空時(shí)返回的默認(rèn)值。
下面的代碼僅供參考: def my_max(*args, key=None, default=None): """ 獲取可迭代對(duì)象中最大的元素或兩個(gè)及以上實(shí)參中最大的元素 :param args:
一個(gè)可迭代對(duì)象或多個(gè)元素 :param key: 提取用于元素比較的特征值的函數(shù),默認(rèn)為None :param default: 如果可迭代對(duì)象為空則返回該默認(rèn)值,如果沒(méi)有給默認(rèn)值則引發(fā)ValueError異常 :return: 返回可迭代對(duì)象或多個(gè)元素中的最大元素 """ if len(args) == 1 and len(args[0]) == 0: if default: return default else: raise ValueError('max() arg is an empty sequence') items = args[0] if len(args) == 1 else args max_elem, max_value = items[0], items[0] if key: max_value = key(max_value) for item in items: value = item if key: value = key(item) if value > max_value: max_elem, max_value = item, value return max_elem