python實(shí)操題目及答案_第1頁
python實(shí)操題目及答案_第2頁
python實(shí)操題目及答案_第3頁
python實(shí)操題目及答案_第4頁
python實(shí)操題目及答案_第5頁
已閱讀5頁,還剩7頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

python實(shí)操題目及答案Python實(shí)操題目及答案1.題目:字符串反轉(zhuǎn)要求:編寫一個(gè)Python函數(shù),實(shí)現(xiàn)將輸入的字符串反轉(zhuǎn)。代碼:```pythondefreverse_string(s):returns[::-1]測試print(reverse_string("hello"))輸出:olleh```答案:函數(shù)`reverse_string`接受一個(gè)字符串參數(shù)`s`,并使用切片操作`[::-1]`來實(shí)現(xiàn)字符串的反轉(zhuǎn)。2.題目:列表去重要求:給定一個(gè)列表,編寫一個(gè)Python函數(shù),返回一個(gè)新列表,包含原列表中所有不重復(fù)的元素。代碼:```pythondefremove_duplicates(lst):returnlist(set(lst))測試print(remove_duplicates([1,2,2,3,4,4,5]))輸出:[1,2,3,4,5]```答案:函數(shù)`remove_duplicates`接受一個(gè)列表`lst`作為參數(shù),利用`set`數(shù)據(jù)結(jié)構(gòu)的特性去除重復(fù)元素,然后轉(zhuǎn)換回列表。3.題目:計(jì)算階乘要求:編寫一個(gè)Python函數(shù),計(jì)算并返回一個(gè)整數(shù)的階乘。代碼:```pythondeffactorial(n):ifn==0:return1else:returnnfactorial(n-1)測試print(factorial(5))輸出:120```答案:函數(shù)`factorial`使用遞歸的方式計(jì)算階乘。如果輸入為0,則直接返回1;否則,計(jì)算`n`乘以`n-1`的階乘。4.題目:斐波那契數(shù)列要求:編寫一個(gè)Python函數(shù),返回一個(gè)斐波那契數(shù)列的列表,包含前n個(gè)斐波那契數(shù)。代碼:```pythondeffibonacci(n):fib_sequence=[0,1]whilelen(fib_sequence)<n:fib_sequence.append(fib_sequence[-1]+fib_sequence[-2])returnfib_sequence[:n]測試print(fibonacci(10))輸出:[0,1,1,2,3,5,8,13,21,34]```答案:函數(shù)`fibonacci`初始化一個(gè)包含前兩個(gè)斐波那契數(shù)的列表,然后通過循環(huán)計(jì)算后續(xù)的斐波那契數(shù),直到列表長度達(dá)到`n`。5.題目:二分查找要求:給定一個(gè)已排序的列表和一個(gè)目標(biāo)值,編寫一個(gè)Python函數(shù),返回目標(biāo)值在列表中的索引,如果不存在則返回-1。代碼:```pythondefbinary_search(arr,target):left,right=0,len(arr)-1whileleft<=right:mid=(left+right)//2ifarr[mid]==target:returnmidelifarr[mid]<target:left=mid+1else:right=mid-1return-1測試print(binary_search([1,2,3,4,5,6],4))輸出:3```答案:函數(shù)`binary_search`使用二分查找算法,通過不斷縮小搜索范圍來查找目標(biāo)值。6.題目:合并兩個(gè)有序列表要求:給定兩個(gè)已排序的列表,編寫一個(gè)Python函數(shù),將它們合并成一個(gè)有序列表。代碼:```pythondefmerge_sorted_lists(list1,list2):merged_list=[]i,j=0,0whilei<len(list1)andj<len(list2):iflist1[i]<list2[j]:merged_list.append(list1[i])i+=1else:merged_list.append(list2[j])j+=1merged_list.extend(list1[i:])merged_list.extend(list2[j:])returnmerged_list測試print(merge_sorted_lists([1,3,5],[2,4,6]))輸出:[1,2,3,4,5,6]```答案:函數(shù)`merge_sorted_lists`通過比較兩個(gè)列表中的元素并將較小的元素添加到結(jié)果列表中,直到一個(gè)列表為空,然后將另一個(gè)列表的剩余元素添加到結(jié)果列表中。7.題目:找出數(shù)組中第二大的數(shù)要求:給定一個(gè)數(shù)組,編寫一個(gè)Python函數(shù),找出數(shù)組中第二大的數(shù)。代碼:```pythondeffind_second_largest(arr):iflen(arr)<2:returnNonefirst,second=float('-inf'),float('-inf')fornuminarr:ifnum>first:second=firstfirst=numelifnum>secondandnum!=first:second=numreturnsecond測試print(find_second_largest([10,5,20,15]))輸出:15```答案:函數(shù)`find_second_largest`通過遍歷數(shù)組,使用兩個(gè)變量`first`和`second`來跟蹤最大和第二大的數(shù)。8.題目:檢查回文鏈表要求:給定一個(gè)鏈表,編寫一個(gè)Python函數(shù),檢查它是否是回文的。代碼:```pythonclassListNode:def__init__(self,value=0,next=None):self.value=valueself.next=nextdefis_palindrome(head):ifnotheadornothead.next:returnTruefast,slow=head,headwhilefastandfast.next:fast=fast.next.nextslow=slow.nextsecond_half=reverse(slow)first_half=headwhilesecond_half:iffirst_half.value!=second_half.value:returnFalsefirst_half=first_half.nextsecond_half=second_half.nextreturnTruedefreverse(head):prev,curr=None,headwhilecurr:next_node=curr.nextcurr.next=prevprev=currcurr=next_nodereturnprev測試構(gòu)建鏈表1->2->2->1node1=ListNode(1)node2=ListNode(2)node3=ListNode(2)node4=ListNode(1)node1.next=n

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論