麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發(fā)設(shè)計 > 正文

Leetcode 189. Rotate Array

2019-11-10 20:09:59
字體:
供稿:網(wǎng)友

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

//方法1:利用三次reverseclass Solution {public: void rotate(vector<int>& nums, int k) { //bug:k可能很大,又默認是在范圍內(nèi) 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){//結(jié)束條件是k=k%n,k==0,說明已經(jīng)rotate完成 for(int i=0;i<k;i++){ swap(nums[start+i],nums[start+i+n-k]); } } }};
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久久久久久91 | 99精品视频在线观看免费 | 中文字幕h | 免费看一级毛片欧美 | 国产精品一区在线看 | 成人免费在线网 | 久久国产精品电影 | 日本在线播放一区二区三区 | 精品69人人人人 | 亚洲午夜1000理论片aa | 久草在线综合网 | 免费视频aaa | 毛片在线视频免费观看 | 亚洲日本韩国在线观看 | 欧美性生活视频免费 | 国产精品一区在线观看 | 国产精品久久久久久久久久免 | 久久久国产视频 | 国产色视频免费 | 欧美大屁股精品毛片视频 | 日韩黄在线 | 国产一级二级在线播放 | 牛牛碰在线 | 国产91一区| 高清国产午夜精品久久久久久 | xxxxxx中国 | 亚洲va久久久噜噜噜久牛牛影视 | 国产高清一区 | 天堂在线资源av | 日日草夜夜操 | 毛片在线免费视频 | 亚洲午夜久久久久 | 手机国产乱子伦精品视频 | 黄色毛片免费看 | 久久91亚洲精品久久91综合 | 做爰xxxⅹ性护士hd在线 | 毛片大全免费看 | 91短视频网页版 | 欧美亚洲综合网 | 日韩欧美精品电影 | 亚洲成人激情av |