91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

      手機(jī)站
      千鋒教育

      千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

      千鋒教育

      掃一掃進(jìn)入千鋒手機(jī)站

      領(lǐng)取全套視頻
      千鋒教育

      關(guān)注千鋒學(xué)習(xí)站小程序
      隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

      當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Python3實(shí)現(xiàn)旋轉(zhuǎn)數(shù)組的3種算法

      Python3實(shí)現(xiàn)旋轉(zhuǎn)數(shù)組的3種算法

      來(lái)源:千鋒教育
      發(fā)布人:xqq
      時(shí)間: 2023-11-06 03:50:39 1699213839

      下面是Python3實(shí)現(xiàn)的旋轉(zhuǎn)數(shù)組的3種算法。

      一、題目

      給定一個(gè)數(shù)組,將數(shù)組中的元素向右移動(dòng)k個(gè)位置,其中k是非負(fù)數(shù)。

      例如:

      輸入:[1,2,3,4,5,6,7]和k=3

      輸出:[5,6,7,1,2,3,4]

      解釋:

      向右旋轉(zhuǎn)1步:[7,1,2,3,4,5,6]

      向右旋轉(zhuǎn)2步:[6,7,1,2,3,4,5]

      向右旋轉(zhuǎn)3步:[5,6,7,1,2,3,4]

      說(shuō)明:

      1.盡可能想出更多的解決方案,至少有三種不同的方法可以解決這個(gè)問(wèn)題。

      2.要求使用空間復(fù)雜度為O(1)的原地算法。

      二、解題算法

      解法一

      以倒數(shù)第k個(gè)值為分界線(xiàn),把nums截成兩組再組合。因?yàn)閗可能大于nums的長(zhǎng)度(當(dāng)這兩者相等的時(shí)候,就相當(dāng)于nums沒(méi)有移動(dòng)),所以我們?nèi)%len(nums),k和nums的長(zhǎng)度取余,就是最終我們需要移動(dòng)的位置

      代碼如下:

      ifnums:

      k=k%len(nums)

      nums[:]=nums[-k:]+nums[:-k]

      時(shí)間:64ms

      假設(shè):

      nums=[1,2,3,4,5,6,7]

      k=3

      運(yùn)行結(jié)果:

      [5,6,7,1,2,3,4]

      解法二

      先把nums最后一位移動(dòng)到第一位,然后刪除最后一位,循環(huán)k次。k=k%len(nums),取余

      代碼如下:

      ifnums:

      k=k%len(nums)

      whilek>0:

      k-=1

      nums.insert(0,nums[-1])

      nums.pop()

      時(shí)間:172ms

      假設(shè):

      nums=[1,2,3,4,5,6,7]

      k=3

      運(yùn)行結(jié)果:

      [5,6,7,1,2,3,4]

      解法三

      先把nums復(fù)制到old_nums,然后nums中索引為x的元素移動(dòng)k個(gè)位置后,當(dāng)前索引為x+k,其值為old_nums[x]。,所以我們把x+k處理成(x+k)%len(nums),取余操作,減少重復(fù)的次數(shù)。

      代碼如下:

      ifnums:

      old_nums=nums[:]

      l=len(nums)

      forxinrange(l):

      nums[(x+k)%l]=old_nums[x]

      時(shí)間:64ms

      假設(shè):

      nums=[1,2,3,4,5,6,7]

      k=3

      運(yùn)行結(jié)果:

      [5,6,7,1,2,3,4]

      以上內(nèi)容為大家介紹了Python3實(shí)現(xiàn)旋轉(zhuǎn)數(shù)組的3種算法,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://www.jsszjs.cn/

      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
      請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
      免費(fèi)領(lǐng)取
      今日已有369人領(lǐng)取成功
      劉同學(xué) 138****2860 剛剛成功領(lǐng)取
      王同學(xué) 131****2015 剛剛成功領(lǐng)取
      張同學(xué) 133****4652 剛剛成功領(lǐng)取
      李同學(xué) 135****8607 剛剛成功領(lǐng)取
      楊同學(xué) 132****5667 剛剛成功領(lǐng)取
      岳同學(xué) 134****6652 剛剛成功領(lǐng)取
      梁同學(xué) 157****2950 剛剛成功領(lǐng)取
      劉同學(xué) 189****1015 剛剛成功領(lǐng)取
      張同學(xué) 155****4678 剛剛成功領(lǐng)取
      鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
      董同學(xué) 138****2867 剛剛成功領(lǐng)取
      周同學(xué) 136****3602 剛剛成功領(lǐng)取
      相關(guān)推薦HOT
      Python標(biāo)準(zhǔn)庫(kù)中自帶的單元測(cè)試框架

      Unittest是Python標(biāo)準(zhǔn)庫(kù)中自帶的單元測(cè)試框架,支持自動(dòng)化測(cè)試,測(cè)試用例的初始化和關(guān)閉測(cè)試用例的聚合等功能。有一些類(lèi)似于Java中的Junit單元...詳情>>

      2023-11-06 06:57:52
      有Java基礎(chǔ)的學(xué)習(xí)python應(yīng)該注意些什么

      首先,對(duì)于具有Java編程基礎(chǔ)的人來(lái)說(shuō),學(xué)習(xí)Python的初期并不會(huì)遇到太大的障礙,但是要結(jié)合自己的發(fā)展規(guī)劃來(lái)制定學(xué)習(xí)規(guī)劃,尤其要重視學(xué)習(xí)方向的...詳情>>

      2023-11-06 06:25:27
      Python 定時(shí)修改數(shù)據(jù)庫(kù)

      當(dāng)需要定時(shí)修改數(shù)據(jù)庫(kù)時(shí),一般我們都選擇起一個(gè)定時(shí)進(jìn)程去改庫(kù)。如果將這種定時(shí)任務(wù)寫(xiě)入業(yè)務(wù)中,寫(xiě)成一個(gè)接口呢,定時(shí)進(jìn)程顯得有些不太合適?如...詳情>>

      2023-11-06 06:03:51
      Python有哪些常用函數(shù)?

      Python常用函數(shù)有哪些?我想大家都比較好奇這個(gè)問(wèn)題,今天小編特地整理了一篇有關(guān)Python常用函數(shù)的相關(guān)內(nèi)容,接下來(lái)我們一起來(lái)看看具體的內(nèi)容介...詳情>>

      2023-11-06 05:49:27
      Python常用的三大開(kāi)源框架

      眾所周知,Python是一種腳本語(yǔ)言,具有易學(xué)、語(yǔ)法清晰、易維護(hù)等優(yōu)點(diǎn),而且具有豐富和強(qiáng)大的庫(kù),被稱(chēng)作為膠水語(yǔ)言。Python語(yǔ)言誕生較早,經(jīng)過(guò)多...詳情>>

      2023-11-06 05:35:03
      快速通道