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

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

Leetcode 189. Rotate Array

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

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
亚洲综合一区二区不卡| 日韩激情av在线播放| 国产精品一区=区| 亚洲精品xxx| 国产精品免费看久久久香蕉| 日韩成人在线视频| 97视频人免费观看| 久久久最新网址| 国产精品成人aaaaa网站| 亚洲免费视频在线观看| 成人国内精品久久久久一区| 日韩成人黄色av| 欧美激情精品久久久久| 欧美电影在线观看| 亚洲激情成人网| 综合激情国产一区| 久久99久久亚洲国产| 国产亚洲欧洲在线| 成人性生交xxxxx网站| 国产一区二区三区久久精品| 国产精品激情av在线播放| 日韩欧美中文在线| 成人免费视频a| 日韩中文字幕在线免费观看| 成人久久一区二区| 亚洲 日韩 国产第一| 一区二区三区美女xx视频| 国产日韩在线视频| 日韩av一区在线| 久久久精品免费视频| 中文字幕av日韩| 一色桃子一区二区| 久久精品亚洲热| 国产精品日韩av| 性色av一区二区咪爱| 一区二区三区四区精品| 欧美色欧美亚洲高清在线视频| 日本亚洲欧美成人| 欧美日韩中国免费专区在线看| 国产精品美女av| 亚洲网站在线看| 久久视频免费在线播放| 国产欧美久久一区二区| 成人网页在线免费观看| 亚洲精品一区久久久久久| 亚洲色图激情小说| 国产在线日韩在线| 亚洲伦理中文字幕| 在线看福利67194| 超薄丝袜一区二区| 51ⅴ精品国产91久久久久久| 久久精品视频亚洲| 国产一级揄自揄精品视频| 久久久久国产精品www| 国产精选久久久久久| 国产一区二区三区在线观看网站| 久久综合久久美利坚合众国| 91视频九色网站| 96精品久久久久中文字幕| 亚洲天堂免费观看| 成人免费看吃奶视频网站| 国产精品视频男人的天堂| 欧美国产中文字幕| 国产精品成人av在线| 亚洲欧美日韩国产精品| 亚州国产精品久久久| 亚洲一区二区三区乱码aⅴ| 欧美精品在线第一页| 亚洲国产一区二区三区四区| 日韩欧美视频一区二区三区| www日韩中文字幕在线看| 国产免费成人av| 欧美中文在线视频| 国产精品私拍pans大尺度在线| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美在线激情网| 热re99久久精品国产66热| 日韩精品有码在线观看| 性欧美xxxx| 欧美午夜影院在线视频| 国产成人精彩在线视频九色| 国产精品一区久久久| 国产偷国产偷亚洲清高网站| 欧美精品做受xxx性少妇| 国产精品v日韩精品| 日韩女优在线播放| 亚洲香蕉伊综合在人在线视看| 国产日产久久高清欧美一区| 久久久久久综合网天天| 国产精品女主播| 国产一区二区三区直播精品电影| 精品久久久久久久久久久久| 亚洲美女精品成人在线视频| 91视频免费在线| 日韩精品免费一线在线观看| 国产精品午夜视频| 成人乱人伦精品视频在线观看| 精品久久久久久国产| 国产精品永久免费视频| 精品久久香蕉国产线看观看gif| 92国产精品视频| 欧美激情视频给我| 久久琪琪电影院| 亚洲免费影视第一页| 91精品国产成人| 日韩高清不卡av| 国产精品久久久久久一区二区| 亚洲美女在线视频| 亚洲va欧美va国产综合剧情| 亚洲xxxx视频| 韩国精品久久久999| 人人做人人澡人人爽欧美| 日韩在线观看你懂的| 欧美日韩国产激情| 日本久久久久久久| 成人久久久久久| 久久精品国产成人| www国产亚洲精品久久网站| 亚洲精品v欧美精品v日韩精品| 欧美午夜女人视频在线| 欧美日韩免费观看中文| 成人国产精品一区二区| 欧美激情videoshd| 国产z一区二区三区| 久久精品这里热有精品| 日韩高清不卡av| 国产精品久久久久高潮| 中日韩美女免费视频网站在线观看| 成人免费福利在线| 亚洲综合自拍一区| 亚洲国产小视频在线观看| 欧美成人亚洲成人日韩成人| 亚洲一区二区久久久久久久| 亚洲人精选亚洲人成在线| 亚洲a中文字幕| 91久久久亚洲精品| 海角国产乱辈乱精品视频| 国产视频欧美视频| 欧美精品在线免费| 日韩欧美在线一区| 国产精品免费一区| 亚洲精品福利在线观看| 欧美剧在线观看| 亚洲小视频在线观看| 久久精品免费播放| 亚洲精品一区二三区不卡| 亚洲国产一区二区三区在线观看| 国产玖玖精品视频| 亚洲精品中文字幕av| 日韩av中文在线| 91香蕉嫩草神马影院在线观看| 91在线观看免费| 在线看欧美日韩| 日韩欧美国产骚| 日日噜噜噜夜夜爽亚洲精品| 国产视频久久久久| 久久精品一本久久99精品| 欧美大片免费观看在线观看网站推荐| 国产日韩综合一区二区性色av| 国产91精品不卡视频| 亚洲黄色在线观看| 欧美一区二区三区四区在线| 亚洲福利视频专区| 成人中文字幕+乱码+中文字幕|