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

首頁 > 編程 > C++ > 正文

第二周:( LeetCode241 ) Different Ways to Add Parentheses(c++)

2019-11-06 08:09:04
字體:
來源:轉載
供稿:網友

最近算法課在學習分治算法,在leetcode做了幾道easy和medium的題。運用分治算法的前提是:(1)把問題分成幾個同構的子問題(2)遞歸地解決每一個子問題(3)把各個子問題的答案結合起來構成原問題的答案。分治算法的復雜度分析可以通過大師定理。 個人感覺分治如果用得好,確實可以達到提高效率的作用。但如果處理得不夠妥當,有時會因為遞歸函數的層層嵌套,造成爆空間、超時等問題出現,得不償失。所以在寫代碼時一定要注意精簡,不要冗余,注意算法的復雜度! 下面主要結合leetcode241題的求解過程進行分析。

原題:Given a string of numbers and Operators, return all possible results from computing all the different possible ways to group numbers and operators. The valid operators are +, - and *.

Example 1 Input: “2-1-1”. ((2-1)-1) = 0 (2-(1-1)) = 2 Output: [0, 2]

Example 2 Input: “2*3-4*5” (2*(3-(4*5))) = -34 ((2*3)-(4*5)) = -14 ((2*(3-4))*5) = -10 (2*((3-4)*5)) = -10 (((2*3)-4)*5) = 10 Output: [-34, -14, -10, -10, 10]

思路:其實本題用分治的思路并不難想。從左至右遍歷字符串,遇到“+”“-”“*”的符號時,把符號左右兩邊分成兩個子字符串,再調用函數遞歸求解。

解法一:

#include<string>#include<vector>class Solution {public: vector<int> diffWaysToCompute(string input) { string s1,s2; vector<int> res; vector<int> res1,res2; s1.clear(); s2.clear(); res.clear(); res1.clear(); res2.clear(); if(!have_symbol(input)){ res.push_back(string_to_int(input)); return res; }else{ for(int i=0;i<input.length();i++){ s1=input.substr(0,i); s2=input.substr(i+1,input.length()-i-1); res1=diffWaysToCompute(s1); res2=diffWaysToCompute(s2); if(input[i]=='-'){ for(int m=0;m<res1.size();m++){ for(int n=0;n<res2.size();n++){ res.push_back(res1[m]-res2[n]); } } continue; } if(input[i]=='+'){ for(int m=0;m<res1.size();m++){ for(int n=0;n<res2.size();n++){ res.push_back(res1[m]+res2[n]); } } continue; } if(input[i]=='*'){ for(int m=0;m<res1.size();m++){ for(int n=0;n<res2.size();n++){ res.push_back(res1[m]*res2[n]); } } continue; } } } return res; } bool have_symbol(string s){ for(int i=0;i<s.length();i++){ if((s[i]=='+')||(s[i]=='-')||(s[i]=='*')){ return true; } } return false; } int string_to_int(string s){ int now,PRe,res; res=0; for(int i=0;i<s.length();i++){ pre=res; now=s[i]-'0'; res=pre*10+now; } return res; }};

剛開始的代碼寫得有點冗余,結果是: 24 / 25 test cases passed. Status: Time Limit Exceeded。

解法二: 經過仔細分析,解法一的冗余主要體現在: (1)bool have_symbol(string s)這個函數本來是為了判斷字符串里面是否是單純的數字;如果是只有數字沒有符號就返回false。其實在 vector diffWaysToCompute(string input)中,如果遍歷完字符串之后,用條件res.size()=0即可判斷字符串中不存在符號。如此一來,就省去了每一層的string都走一遍bool have_symbol(string s)函數,可明顯提高效率。 (2) vector diffWaysToCompute(string input)這個函數中,這四個語句: s1=input.substr(0,i);s2=input.substr(i+1,input.length()-i-1);res1=diffWaysToCompute(s1);res2=diffWaysToCompute(s2); 應該是在input[i]==’-‘或’+’或’*’時才跑,不然的話完全沒必要。

改進了這兩處之后,代碼簡潔了很多,也很順利3ms通過了所有樣例。

#include<string>#include<vector>class Solution {public: vector<int> diffWaysToCompute(string input) { string s1,s2; vector<int> res,res1,res2; s1.clear();s2.clear(); res.clear();res1.clear();res2.clear(); for(int i=0;i<input.length();i++){ if((input[i]=='-')||(input[i]=='+')||(input[i]=='*')){ s1=input.substr(0,i); s2=input.substr(i+1,input.length()-i-1); res1=diffWaysToCompute(s1); res2=diffWaysToCompute(s2); for(int m=0;m<res1.size();m++){ for(int n=0;n<res2.size();n++){ if(input[i]=='-'){ res.push_back(res1[m]-res2[n]); }else if(input[i]=='+'){ res.push_back(res1[m]+res2[n]); }else{ res.push_back(res1[m]*res2[n]); } } } } } if(res.size()==0){ res.push_back(string_to_int(input)); } return res; } int string_to_int(string s){ int now,pre,res; res=0; for(int i=0;i<s.length();i++){ pre=res; now=s[i]-'0'; res=pre*10+now; } return res; }};

這個故事告訴我,我的代碼能力仍然很弱。 當然此題只是過了,還遠不是最佳解。顯然上述解法對子問題存在著重復計算的問題,如果能夠保存子問題的答案,效率肯定會更高,這是算法方面的問題。以后如果有時間,可以繼續進行改進。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲天堂第二页| 国产精品福利网| 国产97在线|日韩| 北条麻妃99精品青青久久| 欧美多人爱爱视频网站| 啪一啪鲁一鲁2019在线视频| 欧美成人四级hd版| 欧美成年人视频网站欧美| 2025国产精品视频| 色综合久久悠悠| 欧美日韩国产丝袜另类| 97国产真实伦对白精彩视频8| 国产精品av在线| 国产做受69高潮| 日韩精品999| 欧美性精品220| 国产免费一区二区三区香蕉精| 日本视频久久久| 亚洲国产私拍精品国模在线观看| 这里只有精品丝袜| 亚洲精品动漫久久久久| 91av视频导航| 欧美二区乱c黑人| 日产精品99久久久久久| 日本久久久a级免费| 亚洲综合中文字幕68页| 欧美黄色片视频| 亚洲精品久久久久久久久久久久| 亚洲国产高清福利视频| 国产精品第2页| 欧美性猛交xxxx久久久| 一区二区三欧美| 久久久久久久久久亚洲| 97久久精品人人澡人人爽缅北| 91视频-88av| 欧美激情二区三区| 亚洲春色另类小说| 亚洲综合最新在线| 亚洲女人被黑人巨大进入| 国产精品久久视频| 欧美成人精品影院| 国产自产女人91一区在线观看| 美女久久久久久久久久久| 国产午夜精品麻豆| 国产精品无av码在线观看| 成人免费淫片aa视频免费| 97在线观看视频国产| 国产在线日韩在线| 日韩av综合网| 国产精品久久久久久久久久久久久久| 成人午夜一级二级三级| 欧美成人第一页| 久久精品国产亚洲精品2020| 九九热99久久久国产盗摄| 精品中文字幕在线2019| 成人激情黄色网| 国产精品高潮呻吟视频| 成人黄色av免费在线观看| 亚洲人成电影网站色| 欧美成人免费观看| 欧美在线观看日本一区| 久久久精品在线| 久久影视免费观看| 亚州成人av在线| 国产视频精品在线| 日韩精品欧美国产精品忘忧草| 亚洲黄页网在线观看| 欧美性猛交xxxx黑人猛交| 亚洲欧洲一区二区三区在线观看| 欧美激情a∨在线视频播放| 91久久久久久久一区二区| 久久精品国产免费观看| 日韩福利视频在线观看| 久久国产精品视频| 91视频国产高清| 伊人久久大香线蕉av一区二区| 久久夜精品香蕉| 欧美成年人视频| 精品亚洲男同gayvideo网站| 91精品国产91久久久久久不卡| 久久深夜福利免费观看| 爽爽爽爽爽爽爽成人免费观看| 欧美成人在线网站| 国产精品成人久久久久| 亚洲一区二区国产| 亚洲午夜小视频| 亚洲一区二区久久久久久久| 欧美成人精品在线播放| 成人精品久久av网站| 韩国三级电影久久久久久| 亚洲欧洲在线观看| 日韩成人高清在线| 欧美色videos| 一本色道久久88综合日韩精品| 亚洲a∨日韩av高清在线观看| 国产精品久久久久久亚洲影视| 久久777国产线看观看精品| 在线免费观看羞羞视频一区二区| 亚洲欧美成人一区二区在线电影| 国产日韩在线看片| 成人伊人精品色xxxx视频| 97在线视频精品| 秋霞av国产精品一区| 亚洲欧美综合精品久久成人| 激情成人中文字幕| 自拍偷拍免费精品| 综合国产在线视频| 91在线色戒在线| 国内揄拍国内精品少妇国语| 久久不射电影网| 国产亚洲福利一区| 日韩av免费在线播放| 欧美一区第一页| 国产精品444| 久久亚洲精品毛片| 日韩免费精品视频| 亚洲日本欧美日韩高观看| 一本一本久久a久久精品牛牛影视| 亚洲成人激情图| 国产精品一区二区三区免费视频| 欧美综合在线观看| 亚洲国产精品yw在线观看| 不卡av电影在线观看| 最近2019好看的中文字幕免费| 久久99精品久久久久久青青91| 大桥未久av一区二区三区| 久久免费视频在线观看| 日本一区二区在线播放| 在线观看日韩视频| 亚洲成人在线视频播放| 亚洲成人在线视频播放| 亚洲成av人片在线观看香蕉| 欧美人与性动交a欧美精品| 日韩av在线免费观看一区| 日本精品久久久久久久| 国产午夜精品全部视频在线播放| 亚洲va国产va天堂va久久| 欧美性感美女h网站在线观看免费| x99av成人免费| 亚洲成人久久电影| 亚洲aⅴ日韩av电影在线观看| 成人国产精品日本在线| 91成品人片a无限观看| 国产精品电影网| 中文日韩电影网站| 97不卡在线视频| 国产精品爽黄69| 午夜精品理论片| 久久精品国产综合| 日韩女优在线播放| 日韩在线视频免费观看高清中文| 成人免费网站在线观看| 成人天堂噜噜噜| 久久久久久亚洲精品| 亚洲最新av在线网站| 日韩在线www| 欧美高清电影在线看| 91高清视频免费观看| 亚洲欧美国产视频| 欧美日韩不卡合集视频| 欧美野外wwwxxx| 欧美裸体视频网站| 国产福利精品在线| 亚洲欧美一区二区精品久久久|