以后看到个数比较少,性能比较高,就要第一时间想到位操作!

这道题目mock没有通过。超时了。。。。。。

原来题目解法的思路非常非常好!

开始我关注于降低n*n的复杂度,但是这道题目复杂度高在每个字符串长,所以一定要问清楚题目

新做的记录:
package com.company;

import java.util.*;
import java.util.List; class Solution {
public int maxProduct(String[] words) {
// int是32位,足够处理了。真的很牛逼
// 以后看到个数比较少,性能比较高,就要第一时间想到位操作!
// 开始我关注于降低n*n的复杂度,但是这道题目复杂度高在每个字符串长,所以一定要问清楚题目
List<Integer> ilist = new ArrayList<>();
for (int i=0; i<words.length; i++) {
int nb = 0;
for (int j=0; j<words[i].length(); j++) {
nb |= 1 << (words[i].charAt(j) - 'a');
}
ilist.add(nb);
}
int ret = 0;
for (int i=0; i<words.length; i++) {
for (int j=i+1; j<words.length; j++) {
if ((ilist.get(i) & ilist.get(j)) == 0) {
if (words[i].length() * words[j].length() > ret) {
ret = words[i].length() * words[j].length();
}
}
}
}
return ret;
}
} public class Main { public static void main(String[] args) {
// write your code here
System.out.println("Hello");
Solution solution = new Solution(); String[] words= {"cdea","bdd"};
int ret = solution.maxProduct(words);
System.out.printf("Get ret: %d\n", ret); }
}

原来做过的记录

https://leetcode.com/problems/maximum-product-of-word-lengths/

// 我在尽量做到比n*n效率更高
// 对比new solution和previous solution
// new solution 是纯n*n,优化在字符串比较
// 对于大数据,耗时0ms
// previous solution理论上比n*n要快,
// 但是因为涉及vector的频繁增删、复制
// 实际要慢的多,对于大数据耗时800+ms // 总的来看,stl container的复制、删除等,耗时很大 class Solution {
vector<pair<int, int>> vec;
vector<string> words;
int **DP;
// 比较的好方法
int *bits; static bool my_compair(const string &a, const string &b) {
if (a.size() > b.size()) {
return true;
}
else {
return false;
}
} void insert(int i, int j) {
int f = words[i].size() * words[j].size(); int vlen = vec.size();
int begin = 0;
int end = vlen - 1; int mid;
int tmp;
while (begin <= end) {
mid = (begin + end) / 2;
tmp = words[vec[mid].first].size() * words[vec[mid].second].size(); if (f == tmp) {
begin = mid + 1;
break;
}
else if (f > tmp) {
end = mid - 1;
}
else {
begin = mid + 1;
}
}
vec.insert(vec.begin()+begin, make_pair(i, j));
} int valid(int i, int j) {
if ((bits[i] & bits[j]) != 0) {
return 0;
}
return words[i].size() * words[j].size();
} public:
int maxProduct(vector<string>& w) {
words = w; int wlen = words.size();
if (wlen == 0) {
return 0;
}
sort(words.begin(), words.end(), my_compair); // 初始化bits
bits = new int[wlen];
memset(bits, 0, sizeof(int)*wlen);
for (int i=0; i<wlen; i++) {
string wstr = words[i];
int slen = wstr.size();
for (int j=0; j<slen; j++) {
bits[i] |= 1 << (wstr[j]-'a');
}
} // new solution(0 ms for big test case)
int result = 0;
for (int i=0; i<wlen-1; i++) {
for (int j=i+1; j<wlen; j++) {
if ((bits[i]&bits[j]) == 0) {
int tmp = words[i].size() * words[j].size();
if (tmp > result) {
result = tmp;
}
}
}
}
return result; // previous solution (800ms for big test case)
DP = new int*[wlen];
for (int i=0; i<wlen; i++) {
DP[i] = new int[wlen];
// 注意,new出来的数据初始值,不一定为0
memset(DP[i], 0, sizeof(int)*wlen);
} // 根据相乘的长度排序
vec.push_back(make_pair(0, 1));
DP[0][1] = 1; int fir;
int sec;
int tmp; while (!vec.empty()) {
fir = vec[0].first;
sec = vec[0].second;
vec.erase(vec.begin()); tmp = valid(fir, sec);
if (tmp > result) {
result = tmp;
} if (fir + 1 < sec && DP[fir+1][sec] == 0 &&
words[fir+1].size() * words[sec].size() > result) {
insert(fir+1, sec);
DP[fir+1][sec] = 1;
}
if (sec + 1 < wlen && DP[fir][sec+1] == 0 &&
words[fir].size() * words[sec+1].size() > result) {
insert(fir, sec+1);
DP[fir][sec+1] = 1;
}
}
return result;
}
}; // 下面是我在 Mock里面做的,超时了。重来。
package com.company; import java.awt.*;
import java.util.*;
import java.util.List; class Solution {
public int maxProduct(String[] words) {
// 直接用n*n*size的方法肯定不好
// 注意限制条件, lower case的字符 Map<Integer, Set<Integer>> mp = new HashMap<>(); List<Integer> clist = new ArrayList<>(); for (int i=0; i<words.length; i++) {
clist.add(i); // 过滤
char[] chs = words[i].toCharArray();
Set<Integer> wSet = new HashSet();
for (char ch :chs) {
wSet.add(ch - 'a');
}
Iterator<Integer> iter = wSet.iterator();
while (iter.hasNext()) {
int key = iter.next();
if (!mp.containsKey(key)) {
Set<Integer> st = new HashSet<>();
st.add(i);
mp.put(key, st);
}
else {
Set<Integer> st = mp.get(key);
st.add(i);
mp.put(key, st);
}
} } int ret = 0;
for (int i=0; i<words.length; i++) {
Set<Integer> oSet = new HashSet<>(clist);
char[] chs = words[i].toCharArray();
Set<Integer> wSet = new HashSet();
for (char ch :chs) {
wSet.add(ch - 'a');
}
Iterator<Integer> iter = wSet.iterator();
while (iter.hasNext()) {
int key = iter.next();
Set<Integer> st = mp.get(key);
oSet.removeAll(st);
}
iter = oSet.iterator();
while (iter.hasNext()) {
int index = iter.next();
if (words[i].length() * words[index].length() > ret) {
ret = words[i].length() * words[index].length();
}
}
}
return ret; }
} public class Main { public static void main(String[] args) {
// write your code here
System.out.println("Hello");
Solution solution = new Solution(); String[] words= {};
int ret = solution.maxProduct(words);
System.out.printf("Get ret: %d\n", ret); }
}

好!maximum-product-of-word-lengths的更多相关文章

  1. leetcode 318. Maximum Product of Word Lengths

    传送门 318. Maximum Product of Word Lengths My Submissions QuestionEditorial Solution Total Accepted: 1 ...

  2. [LeetCode] Maximum Product of Word Lengths 单词长度的最大积

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

  3. LeetCode 【318. Maximum Product of Word Lengths】

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

  4. 318. Maximum Product of Word Lengths

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

  5. Maximum Product of Word Lengths

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

  6. 318. Maximum Product of Word Lengths ——本质:英文单词中字符是否出现可以用26bit的整数表示

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

  7. Java [Leetcode 318]Maximum Product of Word Lengths

    题目描述: Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where ...

  8. leetcode@ [318] Maximum Product of Word Lengths (Bit Manipulations)

    https://leetcode.com/problems/maximum-product-of-word-lengths/ Given a string array words, find the ...

  9. [Swift]LeetCode318. 最大单词长度乘积 | Maximum Product of Word Lengths

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

  10. [leetcode]318. Maximum Product of Word Lengths单词长度最大乘积

    Given a string array words, find the maximum value of length(word[i]) * length(word[j]) where the tw ...

随机推荐

  1. javascript禁止复制网页内容,兼容三大浏览器

    javascript禁止复制网页内容可以通过以下方式实现:禁止鼠标右键+禁止选中文本. 代码很简单,只需要在head标签的javascript内加入以下两行代码即可. document.onconte ...

  2. maven 构建spring ssh mybatis 配置

    详情参与 http://blog.csdn.net/yuguiyang1990/article/details/8811817 前面我们使用Maven构建了Struts2项目,这里我们来试一下Hibe ...

  3. Sqli-labs less 25a

    Less-25a 不同于25关的是sql语句中对于id,没有''的包含,同时没有输出错误项,报错注入不能用.其余基本上和25示例没有差别.此处采取两种方式:延时注入和联合注入. http://127. ...

  4. Dungeon Game

    The demons had captured the princess (P) and imprisoned her in the bottom-right corner of a dungeon. ...

  5. FZU2165 v11(带权的重复覆盖)

    题意:有n个boss,m种武器,每种武器选用的时候需要有一定的花费ci,然后这个武器可以消灭掉其中一些BOSS,问你消灭完所有的BOSS,需要的最少花费是多少. 当时比赛的时候,看到这题以为是什么网络 ...

  6. HDU 2159 FATE (二维完全背包

    FATE http://acm.hdu.edu.cn/showproblem.php?pid=2159 Problem Description 最近xhd正在玩一款叫做FATE的游戏,为了得到极品装备 ...

  7. Android中两种设置全屏的方法

    设置全屏的两种方法: 第一种:在配置文件里面配置: <?xml version="1.0" encoding="utf-8"?><manife ...

  8. 一步完成 MySQL 向 Redis 迁移

    从mysql搬一个大表到redis中,你会发现在提取.转换或是载入一行数据时,速度慢的让你难以忍受.这里我就要告诉一个让你解脱的小技巧.使用“管道输出”的方式把mysql命令行产生的内容直接传递给re ...

  9. shell基础(一)

    Shell本身是一个用C语言编写的程序,它是用户使用Unix/Linux的桥梁,用户的大部分工作都是通过Shell完成的.Shell既是一种命令语言,又是一种程序设计语言.作为命令语言,它交互式地解释 ...

  10. RSS FEED的应用

    参考:http://inezha.com/help/feedrss 今天工作中遇到了一个知识是RSS FEED.当时觉得很奇怪,我们要这个干嘛用?RSS Feed就是一个xml文件.里面不包含数据,但 ...