当前位置: 首页 > news >正文

为何网站打开慢六安seo

为何网站打开慢,六安seo,大学网站策划方案,wordpress软件分享这道题时间复杂度我感觉设置的不是很好,应该最好是有一个1000变成10000就行。 因为我在做这道题的时候被误导了,以为双重循环暴力判断一下也能过,因为1000*1000 *26的时间复杂度没有到1亿,那么我刚开始认为是能过的,结…

 这道题时间复杂度我感觉设置的不是很好,应该最好是有一个1000变成10000就行。

 因为我在做这道题的时候被误导了,以为双重循环暴力判断一下也能过,因为1000*1000

 *26的时间复杂度没有到1亿,那么我刚开始认为是能过的,结果卡在最后一个用例上了,

 那么后期,我就开始想怎么优化掉那个26,26刚好可以用bitmap(状态压缩)和位运算的思想,

 这样我们可以优化掉那个26的复杂度,这样我们就能过了

 附上第一次暴力解法(卡在最后一个用例)

class Solution {
public:int vv[1100][32];int maxProduct(vector<string>& words) {int n = words.size();for(int i = 0;i < n;i++){for(int j = 0;j <words[i].size();j++){if(words[i][j] < 'a' || words[i][j] > 'z') continue;int index = words[i][j]- 'a';vv[i][index]++;}}int ans = -0x3f3f3f3f;for(int i = 0;i < n;i++){for(int j = 0;j < n;j++){if(i == j) continue;else{bool flag = false;if(words[i].size() >= words[j].size()){for(int c = 0;c < words[i].size();c++){int index = words[i][c]- 'a';if(vv[i][index] && vv[j][index]){flag = true;break;}}}else{for(int c = 0;c < words[j].size();c++){int index = words[i][c]- 'a';if(words[i][c] < 'a' || words[i][c] > 'z') continue;if(vv[i][index] && vv[j][index]){flag = true;break;}}}if(!flag) {int a = words[i].size();int b = words[j].size();ans = max(ans,a * b);}}}}return ans == -0x3f3f3f3f ? 0 : ans;}
};

 正确解法:

 利用int类型有32位,刚好可以通过32位来映射对应的26位小写字母来达到

 比如

 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 

 来了一个字符串"aaccb"

 那么就可以映射成

 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 

 有些不喜欢思考的人还会问,为什么aa这些都映射在一个地方呢

 因为我们根据题目要求的是找到两个字符串中,没有相同的字符

 所以一个字符串有重复的字符就可以默认只有一个这样的字符,

 因为假设"aab" ,"ac" 和 "ab" , "ac",一个字符串中少一个重复字符和多一个重复

 字符没什么区别,所以我们可以将一个字符串中的相同的字符直接映射到同一个位上

 1代表该字符串有该字符,0代表没有

 映射完之后我们怎么办呢?

 //既然用到用整数进行状态压缩了,那么我们就可以根据经验也就是位运算来判断了

 1 1 1 0 0 0 0 0  --- "aaabbc"

 1 0 1 0 0 0 0 0  --- "aaaccc"

 两个数字&一下可以得出一个数字,

 得到 (这个数字代表的是,两个字符串中,相同的字符置为1,不相同的字符置为0)

 1 0 1 0 0 0 0 0

 1 0 1 0 0 0 0 0  ---  "aaaccc"

 0 1 0 0 0 1 0 0  ---  "bbbffff"

 得到  (这个数字代表的色,两个字符串中,相同的字符置为1,不相同的字符置为0)

0 0 0 0 0 0 0 0

那么我们得出一个结论:

如果数字大于0,说明两个字符串中有相同的字符

如果数字等于0,说明两个字符串中没有相同的字符

本题还有一个很小很小的优化

就是双重循环的时候,我们可以去重

假设

1 2 3 4

每个数只与前面的数进行判断,那么就可以去除掉重复的组合了

class Solution {
public:int mask[1100];int maxProduct(vector<string>& words) {int n = words.size();for(int i = 0;i < n;i++){for(int j = 0;j <words[i].size();j++){mask[i] |= (1 << (words[i][j] - 'a'));//状态压缩}}int ans = -0x3f3f3f3f;for(int i = 0;i < n;i++){for(int j = 0;j < i;j++){if(!(mask[i] & mask[j])){int a = words[i].size();int b = words[j].size();ans = max(ans,a * b);}}}return ans == -0x3f3f3f3f ? 0 : ans;}
};

 

http://www.hkea.cn/news/939332/

相关文章:

  • 企业营销型网站建设的可行性西安竞价托管
  • 做网站如何适应分辨率网站分析培训班
  • 现在币圈有那些私募网站做的好百度推广账号登陆入口
  • 旅游网站图片营销公司排名
  • 做服务器的网站都有哪些搜狗关键词排名此会zjkwlgs
  • php动态网站开发 唐四薪 答案b站引流推广网站
  • 长沙3天2晚自由行攻略论述搜索引擎优化的具体措施
  • 外汇局网站做结汇申报被逆冬seo课程欺骗了
  • 网站运营配置免费网站在线观看人数在哪直播
  • 什么网站做一手房好系统优化的例子
  • wordpress 插入wordseo排名点击工具
  • 网站推广易网宣seo的主要分析工具
  • 安徽网站定制最大免费广告发布平台
  • 怎么查网站有没有做404公司宣传网页怎么做
  • 靠谱营销网站开发选哪家seo的优点和缺点
  • 企业网站建设论文文献综述百度推广的广告真实可信吗
  • 企业网站优化方式广州最新消息今天
  • 旅游网站开发的意义seo优化方案案例
  • 山东做网站的公司seo数据分析哪些方面
  • 做网站用哪几个端口 比较好百度贴吧官网网页
  • 弹幕网站是怎么做的百度在线翻译
  • 独立网站域名代发关键词包收录
  • 如何建立门户网站百度可以发布广告吗
  • 网站开发毕设文献郑州网站优化顾问
  • 青海建设银行的官方网站自己制作网页的网站
  • 网站建设的图片叠加步骤过程2021年搜索引擎排名
  • 网站链接到邮箱怎么做搜索引擎推广试题
  • 十堰城市建设网站制作自己的网站
  • 传媒网站建设公司深圳百度seo优化
  • 公司需要网站 该怎么做公司推广咨询