news 2026/5/11 2:13:05

(新卷,100分)- 计算最大乘积(Java JS Python C)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(新卷,100分)- 计算最大乘积(Java JS Python C)

(新卷,100分)- 计算最大乘积(Java & JS & Python & C)

题目描述

给定一个元素类型为小写字符串的数组,请计算两个没有相同字符的元素长度乘积的最大值,

如果没有符合条件的两个元素,返回0。

输入描述

输入为一个半角逗号分隔的小写字符串的数组,2 <= 数组长度<=100,0 < 字符串长度<= 50。

输出描述

两个没有相同字符的元素 长度乘积的最大值

用例

输入iwdvpbn,hk,iuop,iikd,kadgpf
输出14
说明

数组中有5个元素。

iwdvpbn与hk无相同的字符,满足条件,iwdvpbn的长度为7,hk的长度为2,乘积为14(7*2)。

iwdvpbn与iuop、iikd、kadgpf均有相同的字符,不满足条件。

iuop与iikd、kadgpf均有相同的字符,不满足条件。

iikd与kadgpf有相同的字符,不满足条件。

因此,输出为14。

位运算解法

JS算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { console.log(getResult(line.split(","))); }); function getResult(words) { let ans = 0; const n = words.length; const bits = new Array(n).fill(0); for (let i = 0; i < n; i++) { for (let j = 0; j < words[i].length; j++) { bits[i] |= 1 << (words[i][j].charCodeAt() - 97); } } for (let i = 0; i < n; i++) { for (let j = i + 1; j < n; j++) { if ((bits[i] & bits[j]) == 0) { ans = Math.max(ans, words[i].length * words[j].length); } } } return ans; }
Java算法源码
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println(getResult(sc.nextLine().split(","))); } public static int getResult(String[] words) { int ans = 0; int n = words.length; int[] bits = new int[n]; for (int i = 0; i < n; i++) { for (int j = 0; j < words[i].length(); j++) { bits[i] |= 1 << (words[i].charAt(j) - 'a'); } } for (int i = 0; i < n; i++) { for (int j = i + 1; j < n; j++) { if ((bits[i] & bits[j]) == 0) { ans = Math.max(ans, words[i].length() * words[j].length()); } } } return ans; } }
Python算法源码
# 输入获取 words = input().split(",") # 算法入口 def getResult(): ans = 0 n = len(words) bits = [0] * n for i in range(n): for j in range(len(words[i])): bits[i] |= (1 << (ord(words[i][j]) - 97)) for i in range(n): for j in range(i + 1, n): if (bits[i] & bits[j]) == 0: ans = max(ans, len(words[i]) * len(words[j])) return ans # 算法调用 print(getResult())
C算法源码
#include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX(a,b) (a) > (b) ? (a) : (b) int getResult(char ** words, int wordsSize); int main() { char s[5000]; gets(s); char* words[100]; int wordsSize = 0; char* token = strtok(s, ","); while(token != NULL) { words[wordsSize++] = token; token = strtok(NULL, ","); } printf("%d\n", getResult(words, wordsSize)); return 0; } int getResult(char ** words, int wordsSize) { int ans = 0; int* bits = (int*) calloc(wordsSize, sizeof(int)); for(int i=0; i<wordsSize; i++) { for(int j=0; j<strlen(words[i]); j++) { bits[i] |= 1 << (words[i][j] - 'a'); } } for(int i=0; i<wordsSize; i++) { for(int j=i+1; j<wordsSize; j++) { if((bits[i] & bits[j]) == 0) { ans = MAX(ans, strlen(words[i]) * strlen(words[j])); } } } return ans; }

交集解法

JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { const arr = line.split(","); console.log(getResult(arr)); }); function getResult(arr) { let ans = 0; const sets = arr.map((s) => new Set([...s])); for (let i = 0; i < sets.length; i++) { for (let j = i + 1; j < sets.length; j++) { if (disjoint(sets[i], sets[j])) { ans = Math.max(ans, arr[i].length * arr[j].length); } } } return ans; } function disjoint(set1, set2) { for (let c of set1) { if (set2.has(c)) return false; } return true; }
Java算法源码
import java.util.ArrayList; import java.util.Collections; import java.util.HashSet; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String[] strings = sc.nextLine().split(","); System.out.println(getResult(strings)); } public static int getResult(String[] arr) { ArrayList<HashSet<Character>> list = new ArrayList<>(); for (String s : arr) { HashSet<Character> set = new HashSet<>(); for (char c : s.toCharArray()) set.add(c); list.add(set); } int ans = 0; for (int i = 0; i < list.size(); i++) { HashSet<Character> a = list.get(i); for (int j = i + 1; j < list.size(); j++) { HashSet<Character> b = list.get(j); if (Collections.disjoint(a, b)) { ans = Math.max(ans, arr[i].length() * arr[j].length()); } } } return ans; } }
Python算法源码
# 输入获取 arr = input().split(",") # 算法入口 def getResult(): sets = list(map(lambda x: set(x), arr)) ans = 0 for i in range(len(sets)): for j in range(i+1, len(sets)): if sets[i].isdisjoint(sets[j]): ans = max(ans, len(arr[i]) * len(arr[j])) return ans # 算法调用 print(getResult())
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 22:44:46

基于非对称纳什谈判的多微网电能共享运行优化策略Matlab实现

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

作者头像 李华
网站建设 2026/5/2 11:45:44

救命神器9个AI论文平台,本科生搞定毕业论文!

救命神器9个AI论文平台&#xff0c;本科生搞定毕业论文&#xff01; AI 工具助力论文写作&#xff0c;让毕业不走弯路 在当前高校教育中&#xff0c;毕业论文已成为本科生必须面对的一项重要任务。然而&#xff0c;从选题、资料收集到撰写、降重&#xff0c;每一个环节都可能让…

作者头像 李华
网站建设 2026/5/9 7:01:23

【更新】量子遗传算法-遗传粒子群-混沌粒子群附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

作者头像 李华
网站建设 2026/5/6 1:01:57

鸟类保护管理系统小程序-计算机毕业设计源码+LW文档

摘 要 当今社会正处于科技进步与经济社会迅猛发展的全新阶段&#xff0c;国际间的信息交流与学术互动日益频繁。计算机技术对经济社会的发展和民众生活质量的提升产生了深远影响&#xff0c;同时也悄然改变着人类的生存方式与思维模式。传统鸟博士依赖于人工管理方式&#x…

作者头像 李华
网站建设 2026/5/2 9:24:03

java.io.IOException: Previous writer likely failed to write hdfs报错解决方案

本文已收录在Github&#xff0c;关注我&#xff0c;紧跟本系列专栏文章&#xff0c;咱们下篇再续&#xff01; &#x1f680; 魔都架构师 | 全网30W技术追随者&#x1f527; 大厂分布式系统/数据中台实战专家&#x1f3c6; 主导交易系统百万级流量调优 & 车联网平台架构&a…

作者头像 李华
网站建设 2026/5/10 23:55:10

架构 CPU SOC 核心板

1. 架构 & CPU & SOC 先有架构&#xff0c;再有内核&#xff0c;一个架构可以衍生出多种内核 内核之所以称之为内核&#xff0c;是因为他是在SOC、MCU内部中最核心的逻辑处理部分&#xff0c;就是SOC、MCU的CPU。所以内核也可以叫做处理器。 别的公司可以向ARM公司购买…

作者头像 李华