亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Leetcode 189. Rotate Array

2019-11-10 20:30:49
字體:
來源:轉載
供稿:網友

Rotate an array of n elements to the right by k steps.

For example, with n = 7 and k = 3, the array [1,2,3,4,5,6,7] is rotated to [5,6,7,1,2,3,4].

Note: Try to come up as many solutions as you can, there are at least 3 different ways to solve this PRoblem.

s思路: 1. 之前遇到過把matrix rotate,就是用到reverse。這里,也不例外想到reverse。例如:[1,2,3,4,5,6,7],rotate后得到[5,6,7,1,2,3,4]。如何用reverse呢?把[1,2,3,4,5,6,7]先全部reverse成[7,6,5,4,3,2,1],然后把前3個數和后四個數分別再reverse即可! 2. 剛才寫的時候,思維不夠細膩,潛意識或自發的思維已經默認k< n。實際上,沒有這么要求,就可能大于n。 3. 這個方法就是比較系統的方法,沒有去研究誰和誰交換,所以是top down的方法。有沒有面向細節的方法呢?剛嘗試的時候,發現一個。例如:[1,2,3,4,5,6,7],把1和5,2和6,3和7交換,交換k次,即:[5,6,7,4,1,2,3],注意看,我們把前三個數放在了正確的位置上,但后4個數仍然需要繼續rotate,那么我們把數組起始位置變成3,長度變成7-3=4,k=k%4=3,繼續交換:4和1交換,然后4和2交換,最后4和3交換,現在得到[5,6,7,1,2,3,4],此時數組起始位置變成3+3=6,長度變成4-3=1,k=3%1=0,當k==0,說明rotate完成! 4. 整個過程就是iterative的過程,這段時間我們多次遇到。一個問題不能一步解決,我們看是否有一個相同的過程可以應用在這個問題,通過多次使用一個方法,在這個過程中改變一些參數,最后解決問題。一般稍微復雜的問題,都不要期望一步到位,都是多次使用一個方法達到效果。這里就是每次更新需要rotate的序列的起始位置,長度,需要rotate的k!

//方法1:利用三次reverseclass Solution {public: void rotate(vector<int>& nums, int k) { //bug:k可能很大,又默認是在范圍內 k%=nums.size(); reverse(nums.begin(),nums.end());//end()表示最后一個元素之外 reverse(nums.begin(),nums.begin()+k);//注意:nums.begin()+k表示第k+1個元素 reverse(nums.begin()+k,nums.end()); }};//方法2:利用多次swapclass Solution {public: void rotate(vector<int>& nums, int k) { int n=nums.size(); int start=0; for(;k%=n,k>0;n-=k,start+=k){//結束條件是k=k%n,k==0,說明已經rotate完成 for(int i=0;i<k;i++){ swap(nums[start+i],nums[start+i+n-k]); } } }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
这里只有视频精品| 久久久久久亚洲| 国产97色在线| 丁香五六月婷婷久久激情| 国产成人精品视频在线| 亚洲国产日韩精品在线| 免费99精品国产自在在线| 国产一区二中文字幕在线看| 中文字幕日韩在线观看| 精品精品国产国产自在线| 亚洲精品福利在线| 亚洲xxxx18| 国产精品久久久久久av| 亚洲国产精品久久久久秋霞蜜臀| 国产精品激情av电影在线观看| 日韩av一区二区在线| 国语自产精品视频在线看抢先版图片| 亚洲精品电影久久久| 亚洲成人网在线观看| 久久69精品久久久久久久电影好| 日本成人精品在线| 亚洲欧美日韩另类| 久久久久久欧美| 精品国内亚洲在观看18黄| 亚洲综合中文字幕在线观看| 亚洲天堂2020| 色婷婷久久一区二区| 国产精品色悠悠| 色与欲影视天天看综合网| 777精品视频| 久久资源免费视频| 日韩欧美a级成人黄色| 在线观看欧美视频| 1769国产精品| 欧美精品一区在线播放| 国产成人精品在线观看| 欧美激情亚洲一区| 国产日韩亚洲欧美| 亚洲午夜久久久影院| 国模吧一区二区| 成人写真视频福利网| 97免费视频在线播放| 97免费中文视频在线观看| 国产精品网站入口| 日韩a**中文字幕| 色小说视频一区| 欧美裸体男粗大视频在线观看| 成人写真福利网| 成人性生交大片免费观看嘿嘿视频| 亚洲国产欧美在线成人app| 一区二区三区美女xx视频| 亚洲91精品在线| 亚洲精品美女网站| 黑人巨大精品欧美一区二区三区| 精品国产精品自拍| 欧美日韩免费在线观看| 精品无人区太爽高潮在线播放| 一本一本久久a久久精品综合小说| 亚洲精品美女在线观看播放| 亚洲国产精品久久久| 91午夜理伦私人影院| 国产成人综合一区二区三区| 九九热最新视频//这里只有精品| 欧美理论电影网| 欧美激情影音先锋| 成人av在线天堂| 狠狠躁夜夜躁久久躁别揉| 日韩网站免费观看| 欧洲成人午夜免费大片| 久久精品国产99国产精品澳门| 久久福利视频网| 亚洲精品小视频在线观看| 在线观看日韩专区| 91精品国产91久久久久久| 亚洲无限av看| 国产香蕉97碰碰久久人人| 97成人精品视频在线观看| 热草久综合在线| 国产精品99久久久久久www| 国产精品入口日韩视频大尺度| 91九色国产社区在线观看| 亚洲免费小视频| 国产精品福利在线观看网址| 国产小视频国产精品| 日韩成人av在线播放| 精品一区二区三区四区在线| 国产一区二区三区在线免费观看| 亚洲精品国产精品国自产观看浪潮| 亚洲美女性生活视频| 福利一区视频在线观看| 日韩欧美国产视频| 欧美一区二区三区……| 91国在线精品国内播放| 欧美国产日产韩国视频| 久久亚洲精品网站| 欧美精品免费播放| 欧美日韩国产精品| 98精品国产自产在线观看| 日韩中文字幕网站| 亚洲精品国产精品自产a区红杏吧| 最近2019中文字幕在线高清| 国产精品露脸自拍| 亚洲午夜av久久乱码| 日本不卡高字幕在线2019| 亚洲精品视频网上网址在线观看| 尤物精品国产第一福利三区| 国产999视频| 欧美日韩成人黄色| 久久福利视频网| 国产精品久久久久av免费| 午夜精品视频网站| 国产精品自在线| 国产精品扒开腿做爽爽爽视频| 91国内在线视频| 性欧美在线看片a免费观看| 91福利视频网| 久久中文字幕视频| 97国产精品人人爽人人做| 久久久国产精品一区| 中文日韩在线视频| 欧美另类xxx| 国产日本欧美在线观看| 日韩欧美精品网站| 欧美日本亚洲视频| 91精品视频在线看| 91国产美女视频| 久久久噜噜噜久久| 国产999精品久久久| 成人在线一区二区| 成人在线视频福利| 午夜精品久久久99热福利| 国产精品免费视频xxxx| 国产精品中文久久久久久久| 欧美性猛交xxxx乱大交3| 久久av红桃一区二区小说| 精品久久久久久久久久久久| 日韩激情av在线播放| 欧美超级乱淫片喷水| 久久电影一区二区| 日韩中文在线中文网在线观看| 日韩激情视频在线| 久青草国产97香蕉在线视频| 国产日韩欧美夫妻视频在线观看| 97人人做人人爱| www.xxxx欧美| 国产日韩欧美在线视频观看| 久久久久久999| 欧美精品videosex牲欧美| 国产一区二区三区中文| 国产精品一区二区三区久久久| 色妞在线综合亚洲欧美| 亚洲视频axxx| 欧美性猛交xxxx乱大交蜜桃| 91亚洲永久免费精品| 91sao在线观看国产| 插插插亚洲综合网| 成人有码视频在线播放| 精品视频偷偷看在线观看| 91精品视频在线| 日本久久久久久久久| 俺去亚洲欧洲欧美日韩| 亚洲成人精品在线| 亚洲自拍另类欧美丝袜| 国产欧美一区二区|