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

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

分治法學習記錄

2019-11-11 04:43:19
字體:
來源:轉載
供稿:網友

分治法學習記錄

#include <iostream>#include <vector>using namespace std;int maxsum (vector<int> ivec, vector<int>::iterator start, vector<int>::iterator end){ if (start == end) return *start; /*檢查序列是否為空或僅有一個元素*/ vector<int>::iterator mid = start + (end - start)/2; int **maxs** = max(maxsum(ivec, start, mid), maxsum(ivec, mid, end)); /*若最大連續和不過中間*/ int Lsum = 0, Rsum = 0, temp = 0;; vector<int>::iterator iter = mid-1; while (iter-- >= start) Lsum = max(Lsum, temp += *iter); iter = mid; temp = 0; while (iter++ <= end) Rsum = max(Rsum, temp += *iter); /*由中間開始分別向兩邊延伸求求最大連續和序列*/ return max(maxs, Lsum+Rsum);}int main(int argc, const char * **argv**[]) { vector<int> ivec; int num = 0; while(cin >> num) ivec.push_back(num); cout << maxsum(ivec, ivec.begin(), ivec.end()) << endl; return 0;}

先說一點:看遞歸應該廣度優先遍歷!??! 這是我被坑懵逼了無數次得出的結論。。。。。 追求這個函數最后遞歸成啥樣的人都死的很難看。。。。 話說回來,這程序是因為我實在看不過眼書上用數組實現的代碼,于是改成了用vector實現(其實就是改了幾個類型和變量名),然而我不能理解的是, 為什么特么的會有死循環??? 為什么遞歸的時候迭代器出界了??? 我不能理解啊喂?。。?!(╯‵□′)╯︵┻━┻,明明和原代碼一毛一樣?。。?!

咳咳回到正題,分治法:劃分,遞歸解決,合并序列。問題最大的是合并序列,很多情況下這個問題一旦被分開了就合不起來了,書上的大部分例子在剛看到的時候都有這感覺。這其實是人對于遞歸有一定誤解的情況下發生的情況,就像上面說的,別看到遞歸就想著“下一層是啥情況?”“再下面一層是啥情況?”,一般來說,看遞歸,預先了解這函數是干嘛的,得到功能后直接把功能帶入遞歸代碼中,不要硬想著下一層發生了啥,比方說這幾行:

while (iter-- >= start) Lsum = max(Lsum, temp += *iter); iter = mid; temp = 0; while (iter++ <= end) Rsum = max(Rsum, temp += *iter);

真往下層看根本不是個頭,直接從代碼介紹中獲得“這函數獲取這一段中的最大連續和”,代入后即可獲得注釋中寫的內容。 另外,這個程序中用“左閉右開”的集合范圍,好處是在處理“數組分割”時比較自然,區間[x,y)被分為[x,m),[m,y)兩部分,不需要在任何地方加減一。 還有一個細節:x+(y-x)/2來獲取序列的中間值,盡管在數學上這和(x+y)/2結果一樣,但計算機計算時會向下取整,會更自然的分成上面說的形式。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人在线网站| 国产一区深夜福利| 欧美小视频在线| 亚洲国产精久久久久久久| 尤物yw午夜国产精品视频明星| 国产精品羞羞答答| 日韩欧美国产网站| 欧美日韩国产一区中文午夜| 精品无人区乱码1区2区3区在线| 日韩av电影免费观看高清| 国产拍精品一二三| 中文字幕不卡av| 亚洲视频免费一区| 久久影院免费观看| 人人澡人人澡人人看欧美| 欧美一级免费看| 91性高湖久久久久久久久_久久99| 亚洲精品资源美女情侣酒店| 91久久精品久久国产性色也91| 国产精品成人在线| 欧美午夜片在线免费观看| 欧美成人亚洲成人| 国产在线观看不卡| 欧美日韩精品在线| 国产精品一区二区久久久| 日韩久久免费视频| 97香蕉超级碰碰久久免费的优势| 欧美亚洲成人网| 欧美极品在线视频| 中国人与牲禽动交精品| 啊v视频在线一区二区三区| 国产精品久久久久不卡| 亚洲第一色在线| 久久久91精品| 国产亚洲美女久久| 亚洲精品欧美日韩| 日韩成人黄色av| 亚洲精品久久久久中文字幕欢迎你| 日产精品久久久一区二区福利| 久久国产精品电影| 欧美一级电影久久| 亚洲加勒比久久88色综合| 亚洲国产第一页| 国产精品视频免费在线观看| 97香蕉久久夜色精品国产| 欧美成人午夜激情| 国产乱肥老妇国产一区二| 亚洲欧美在线一区二区| 国产亚洲精品一区二555| 精品久久久久国产| 国产成人97精品免费看片| 亚洲男人天堂久| 亚洲人成电影在线观看天堂色| 日韩美女av在线| 久久精品久久久久| 欧美日韩精品中文字幕| www.欧美三级电影.com| 亚洲男人天堂久| 亚洲欧美日韩直播| 日韩电影免费观看在线观看| 97精品视频在线观看| 亚洲成人在线视频播放| 91在线播放国产| 欧美电影在线观看| 欧美视频免费在线观看| 高清视频欧美一级| 精品女同一区二区三区在线播放| 欧美成人免费网| 欧美区二区三区| 亚洲一区第一页| 亚洲久久久久久久久久久| 国产91精品在线播放| 国产精品美女主播在线观看纯欲| 久久久久久中文字幕| 欧美性猛交xxxx免费看漫画| 久久久久久国产精品| 日韩高清免费在线| 精品少妇v888av| 久久精品成人动漫| 久久久亚洲欧洲日产国码aⅴ| 久久香蕉国产线看观看av| 精品国偷自产在线视频| 国产视频精品一区二区三区| 久久的精品视频| 欧美在线www| 国产69精品久久久久久| 久久99久久99精品中文字幕| 欧美最猛性xxxx| 亚洲女性裸体视频| 亚洲国产精品免费| 国产成人精品日本亚洲| 精品伊人久久97| 国产精品入口日韩视频大尺度| 九色精品免费永久在线| 欧美亚洲在线视频| 国产精品久久久久久中文字| 中文字幕免费精品一区| 亚洲黄色成人网| 91免费视频网站| 久久久www成人免费精品张筱雨| 自拍偷拍亚洲在线| 亚洲最大av网站| 不卡av电影在线观看| 亚洲天堂第二页| 岛国精品视频在线播放| www.欧美精品一二三区| 日韩最新中文字幕电影免费看| 狠狠躁18三区二区一区| 欧美巨乳美女视频| 国产自产女人91一区在线观看| 亚洲最大福利网站| 亚洲色图狂野欧美| 国产在线播放不卡| 中文字幕亚洲欧美日韩高清| 欧美性猛交99久久久久99按摩| 日韩av在线高清| 精品自拍视频在线观看| 亚洲电影免费在线观看| 国产精品久久久久久久久免费看| 亚洲自拍在线观看| 亚洲性无码av在线| 欧美亚洲视频一区二区| 日韩精品在线免费观看视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 91成人天堂久久成人| 欧美伊久线香蕉线新在线| 日韩av在线播放资源| 亚洲一区二区在线播放| 91在线视频导航| 久久99国产精品自在自在app| 91亚洲永久免费精品| 亚洲情综合五月天| 国产精品jizz在线观看麻豆| 午夜精品久久久久久久久久久久久| 国产日韩精品综合网站| 久久精品国产精品亚洲| 国产精品视频999| 在线播放国产一区中文字幕剧情欧美| 欧美精品videosex性欧美| 91精品国产沙发| 日韩人在线观看| 国产精品手机播放| 久久91精品国产91久久跳| 欧美在线激情视频| 日韩中文在线观看| 欧美乱妇40p| 黑丝美女久久久| 精品香蕉一区二区三区| 91精品中国老女人| 欧美黄色片在线观看| 亚洲一区二区久久| 国产精品视频久久| 青草成人免费视频| 亚洲欧美精品一区| 日韩成人黄色av| 亚洲美女精品成人在线视频| 久久久久久这里只有精品| 亚洲资源在线看| 亚洲аv电影天堂网| 欧美综合在线第二页| 热久久视久久精品18亚洲精品| 国产免费成人av| 久久久亚洲国产天美传媒修理工| 亚洲成人精品在线|