每日一题 --- 力扣318----最大单词长度乘积

news2024/11/25 14:55:07

 这道题时间复杂度我感觉设置的不是很好,应该最好是有一个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.coloradmin.cn/o/1176167.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用Rust和Scraper库编写图像爬虫的建议

本文提供一些有关如何使用Rust和Scraper库编写图像爬虫的一般建议&#xff1a; 1、首先&#xff0c;你需要安装Rust和Scraper库。你可以通过Rustup或Cargo来安装Rust&#xff0c;然后使用Cargo来安装Scraper库。 2、然后&#xff0c;你可以使用Scraper库的Crawler类来创建一个…

海洋专用cmocean颜色包_共22种--全平台可用

海洋专用cmocean颜色包_共22种–全平台可用 往期推荐&#xff1a; Python语言_matplotlib包_共80种–全平台可用 Python语言_single_color_共140种–全平台可用 R语言_RColorBrewer包–全平台可用 R语言gplots包的颜色索引表–全平台可用 R语言中的自带的调色板–五种–全平台…

Python Tkinter快速入门

一、背景 接了一个小活&#xff0c;需要做一个比特币走势分析小工具&#xff0c;客户希望能安装在Mac上&#xff0c;考虑后决定采用Python的Tkintermatplotlib来做&#xff0c;今天我们就来了快速了解一下Tkinter。 二、Tkinter介绍 Tkinter是Tk的Python版本&#xff0c;而T…

Spring boot集成sentinel限流服务

Sentinel集成文档 Sentinel控制台 Sentinel本身不支持持久化&#xff0c;项目通过下载源码改造后&#xff0c;将规则配置持久化进nacos中&#xff0c;sentinel重启后&#xff0c;配置不会丢失。 架构图&#xff1a; 改造步骤&#xff1a; 接着我们就要改造Sentinel的源码。…

灵活多样的流水号生成方式:JVS低代码表单满足你的各种需求

在数字化时代&#xff0c;表单成为了我们日常生活和工作中不可或缺的一部分。无论是在线申请、数据录入还是业务流程管理&#xff0c;表单都发挥着重要的作用。为了确保数据的准确性和可追溯性&#xff0c;流水号的概念应运而生。流水号作为表单数据记录的唯一标识&#xff0c;…

2022ICPC,济南站(M,E,D

初见安~好久好久没写博客了……感觉还是有必要写的。 拿去年济南的题目训练了一下&#xff0c;状态还不错&#xff0c;写一下自己写过了的题目的题解。 M Best Carry Player 题意&#xff1a;给你n个数&#xff0c;交换他们的顺序使依次相加后总的进位次数最少&#xff08;十…

代码随想录打卡第62天|● 503.下一个更大元素II ● 42. 接雨水

● 503.下一个更大元素II 题目&#xff1a;给定一个循环数组 nums &#xff08; nums[nums.length - 1] 的下一个元素是 nums[0] &#xff09;&#xff0c;返回 nums 中每个元素的 下一个更大元素 。 数字 x 的 下一个更大的元素 是按数组遍历顺序&#xff0c;这个数字之后的第…

蓝桥杯每日一题2023.11.6

取位数 - 蓝桥云课 (lanqiao.cn) 题目描述 题目分析 由题意我们知道len中为现阶段长度&#xff0c;如果其与k相等也就是找到了正确的位数&#xff0c;否则就调用递归来进行搜索&#xff0c;每次搜索一位数。 #include <stdio.h> // 求x用10进制表示时的数位长度 int …

你的停机真的优雅么?第二弹来袭 | 京东云技术团队

1. 前言 之前总结了一篇基于现有业务线在停机重启时会产生RPC和MQ调用强杀导致业务数据不一致文章&#xff0c;文中通过优雅停机改造对RPC服务进行反注册和MQ进行暂停消费&#xff0c;进而可以解决在停机时强制kill掉RPC线程或者MQ线程导致数据不一致现象&#xff0c;具体的原…

DolphinDB 流计算优化实践:时延统计与性能调优

在实时计算中&#xff0c;端到端的响应延迟是衡量计算性能时最重要的指标。DolphinDB 内置的流数据框架支持流数据的发布与订阅、流式增量计算、实时关联等&#xff0c;用户能够快速实现复杂的实时计算任务&#xff0c;达到毫秒级甚至亚毫秒级的效果&#xff0c;而无需编写大量…

这8个Wireshark使用技巧,网工屡试屡爽!

你们好&#xff0c;我的网工朋友。 都懂哈&#xff0c;wireshark是个啥我就不多赘述了&#xff0c;软件功能十分强大就对了。 想安装的可以戳这里&#xff1a;《wireshark下载&安装 》 wireshark作为网工的得力助手&#xff0c;你知道哪些使用技巧&#xff1f; 今天就给…

2023软考-系统架构师一日游

上周六&#xff08;11月4号&#xff09;参见了软考&#xff0c;报的系统架构师&#xff0c;今年下半年是第一次推行机考&#xff0c;简单来分享下大致流程&#xff0c;至于考试难度、考点什么的&#xff0c;这个网上有很多专门研究这些的机构&#xff0c;本人无权发言。考试的经…

每日一题 318. 最大单词长度乘积(中等)

暴力求解没超时&#xff0c;那就这样吧 class Solution:def maxProduct(self, words: List[str]) -> int:ans 0for i in range(len(words)):for j in range(i 1, len(words)):if len(words[i]) * len(words[j]) < ans:continuet 0for k in range(26):ch chr(k ord(…

XCTF-Crypto1

Caesar 题目描述 oknqdbqmoq{kag_tmhq_xqmdzqp_omqemd_qzodkbfuaz} 分析解密 根据题目Caesar推测是凯撒加密 当偏移量为12时&#xff0c;成功得到flag&#xff1a;cyberpeace{you_have_learned_caesar_encryption} Morse 题目描述 11 111 010 000 0 1010 111 100 0 00 000 …

外汇天眼:不要等到被骗才追悔莫及,远离以下被吊销牌照的平台!

监管信息早知道&#xff01;外汇天眼将每周定期公布监管牌照状态发生变化的交易商&#xff0c;以供投资者参考&#xff0c;规避投资风险。如果平台天眼评分过高&#xff0c;建议投资者谨慎选择&#xff0c;因为在外汇天眼评分高不代表平台没问题&#xff01; 以下是监管牌照发生…

FAT32转换成NTFS免费软件Tuxera NTFS2024

很多人在使用电脑时都没有注意过系统中的磁盘是哪种格式。一般目前常用的磁盘格式分为FAT32和NTFS两种。那么它们哪种更适合我们以及如何将磁盘格式转换成该格式呢&#xff1f; Tuxera NTFS2023最新免费版下载如下&#xff1a; https://wm.makeding.com/iclk/?zoneid58824 实…

NTP8918(2x15W双通道立体声内置DSP数字功放)

NTP8918是一款高性能、高保真功率驱动集成全数字音频放大器&#xff1b;内置DSP采用I2S输出&#xff1b;可提供2x15W的输出&#xff08;BTL模式&#xff09;或者30W的单通道输出&#xff08;PBTL模式&#xff09;具备可靠性高、功率足、音色出众、适应能力强等优势。 该芯片工…

【TES745D】青翼自研基于复旦微的FMQL45T900全国产化ARM核心模块(100%国产化)

板卡概述 TES745D是一款基于上海复旦微电子FMQL45T900的全国产化ARM核心板。该核心板将复旦微的FMQL45T900&#xff08;与XILINX的XC7Z045-2FFG900I兼容&#xff09;的最小系统集成在了一个87*117mm的核心板上&#xff0c;可以作为一个核心模块&#xff0c;进行功能性扩展&…

docker安装(超详细)

一.引言 本安装教程参考Docker官方文档&#xff0c;地址如下&#xff1a;https://docs.docker.com/engine/install/centos/ 二.卸载旧版docker(第一次安装可忽略) 首先如果系统中已经存在旧的Docker&#xff0c;则先卸载&#xff1a; yum remove docker \docker-client \docker…

Excel【毫秒】/【秒】转换成【时分秒】/【分秒】

1、毫秒转换秒 2、秒转换时分秒 3、秒转换分秒