JAVA(2021-11-17)leetcode每日一题---- 最大单词长度乘积

leetcode 专栏收录该内容
30 篇文章 0 订阅

这个题的难点并不在于找的过程,因为没有什么可以记录的,就是要挨个比,n平方的复杂度。但是这个题的优化空间在于比较两个单词是否含有公共字母。

一看到是否含有重复的,是否含有重复字符,我们就应该想到是不是可以用位运算,更准确的说是,是否可以使用异或运算,所以我们就要开始考虑是否可以将字母转换为数字表示,我们很容易想到将一个单词转为一个长度为26 的二进制,

a: 1 << 0   0000 0000 0000 0000 0000 0000 0001
z: 1 << 25  0010 0000 0000 0000 0000 0000 0000

即可以转换为这样表示。这样一个字母就解决了,并且考虑到单个单词内的字母可以重复,两个单词之间不可以重复,所以字母内用 或 运算,而字母间用异或运算,问题就迎刃而解了。

        

class Solution {
    public int maxProduct(String[] words) {
        int max = 0;
        int i,j;
        int[] arr = new int[words.length];
        for(i = 0;i<words.length;i++){
         String word=words[i];
            int num=0;
            for (j=0;j<word.length();j++){
                num |= 1 << (word.charAt(j) - 'a');
            }
            arr[i] = num;
        }
        for(i = 0;i<arr.length;i++){
            for(j = 0;j<arr.length;j++){
                if((arr[i] & arr[j]) == 0){
                    max = Math.max(max,words[i].length()*words[j].length());
                }
            }
        }
        return max;
    }
}

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 打赏
    打赏
  • 扫一扫,分享海报

©️2022 CSDN 皮肤主题:深蓝海洋 设计师:CSDN官方博客 返回首页

打赏作者

花园宝宝胡图图

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值