码迷,mamicode.com
首页 > 其他好文 > 详细

运算符号优先级的应用

时间:2017-10-07 20:44:18      阅读:159      评论:0      收藏:0      [点我收藏+]

标签:逻辑或   遍历   amp   匹配   find   str   情况   word   简易   

在一道leetcode的题目中我们深刻

看到C++运算符优先级的应用

如下:

另外简易总结本题的思路:

遍历所有的字符串是必须的,一开始的我的思路如下

排序vector,特殊排序重写compare

[](string &a,string &b){if(a.size()!=b.size()){return a.size()>b.size();}

else{return a<b;}

}

排序完成后,我们进行匹配;

后来,没实现,我在尝试中,看了discuss,觉得方法更好的,只需O(n)遍历一遍,更新最后的string就可以了,排序的复杂度肯定会更高!

class Solution {
public:
string findLongestWord(string s, vector<string>& d) {
string ans;
for (int i = 0; i < d.size(); i++) {
//作为迭代器访问vector<string>& d中的string;
int pi = 0, pj = 0;
for (; pi < s.size() && pj < d[i].size(); pi++) {
pj += s[pi] == d[i][pj];
//+=15级 == 8级
}
//开始查找vector中每个的字符匹配项直到两个字符串一个结束
if (pj == d[i].size() && (ans.size() < d[i].size() || (ans.size() == d[i].size() && ans > d[i])))
//遍历一遍每一个都处理一下时进行,逻辑与13级,逻辑或14级
//pj==d[i].size();判断是否匹配j
//判断ans.size()<d[i].size(),匹配的字符串大小大于目前的ans字符串大小?
//加上另外一种情况 --- 或者ans.size()==d[i].size()且ans>d[i]
{ ans = d[i];}
}
return ans;
}
};

运算符号优先级的应用

标签:逻辑或   遍历   amp   匹配   find   str   情况   word   简易   

原文地址:http://www.cnblogs.com/fenglongyu/p/7635586.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!