在Java中,最大化所有人X的总利润
我们有5个整数变量Num,P1,P2,profit_P1,profit_P2,并且任务是最大化利润,并从范围[1,Num]中的所有自然数中选择。这里的方法是,如果一个正数可以被P1整除,利润增加profit_P1,同样,如果范围内的数字可以被P2整除,利润增加profit_P2。此外,正整数的利润最多只能添加一次。
让我们通过例子来理解:
输入 - int num = 4,P1 = 6,P2 = 2,profit_P1 = 8,profit_P2 = 2;
输出 - 最大化所有人的总利润 X 4
解释 - 这里的数字范围是1到4([1,Num(4)])
系列中没有任何数字可以被P1整除
1和2可以被P2整除
1和2可以被P2整除,得到利润2 * 2 = 4
输入 - num = 3,P1 = 1,P2 = 2,profit_P1 = 3,profit_P2 = 4
输出 - 最大化所有人的总利润 X 10
解释 - 1、2和3都可以被A整除。
2是给定范围中唯一可以被B整除的数字。
2可以被A和B整除。
1和3可以被A整除,得到利润2 * 3 = 6
2可以被B整除,得到利润1 * 4 = 4
2可以被A和B整除,但为了最大化利润,它被B整除而不是A。
下面程序中使用的方法如下 -
我们有6个整数变量,包括正数范围(Num),P1表示第一个人,P2表示第二个人,profit_P1表示第一个人的利润(即如果给定的数字范围中的数字可以被P1整除,则profit_P1增加),以及类似的profit_P2。
在main函数中调用了一个方法(profitMaximisation),该方法是所有计算的实用方法。
在函数内部可以看到,只有当数字是P1或P2的最小公倍数的倍数时,它才能被P1和P2同时整除。此外,它应该被能够提供更多利润的数字除以。
因此,这里的计算方法是profit_P1 * (num / P1) + profit_P2 * (num / P2) - min(profit_P1, profit_P2) * (num / lcm(P1, P2))。
引入了一个方法CalculateGcd()来计算给定数字的最小公倍数。
最终的输出在main方法中捕获并显示给用户。
例子
public class testClass{ static int CalculateGcd(int n1, int n2){ if (n2 == 0) return n1; return CalculateGcd(n2, n1 % n2); } static int profitMaximisation(int n, int a, int b, int x, int y){ int result = x * (n / a); result += y * (n / b); result -= Math.min(x, y) * (n / ((a * b) / CalculateGcd(a, b))); return result; } public static void main(String[] args){ int num = 6, P1 = 6, P2 = 2, profit_P1 = 8, profit_P2 = 2; System.out.println("Maximize the total profit of all the persons X "+profitMaximisation(num, P1, P2, profit_P1, profit_P2)); } }
输出
如果我们运行上面的代码,将会生成以下输出
Maximize the total profit of all the persons X 12
以上是在Java中,最大化所有人X的总利润的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处

胶囊是一种三维几何图形,由一个圆柱体和两端各一个半球体组成。胶囊的体积可以通过将圆柱体的体积和两端半球体的体积相加来计算。本教程将讨论如何使用不同的方法在Java中计算给定胶囊的体积。 胶囊体积公式 胶囊体积的公式如下: 胶囊体积 = 圆柱体体积 两个半球体体积 其中, r: 半球体的半径。 h: 圆柱体的高度(不包括半球体)。 例子 1 输入 半径 = 5 单位 高度 = 10 单位 输出 体积 = 1570.8 立方单位 解释 使用公式计算体积: 体积 = π × r2 × h (4

Spring Boot简化了可靠,可扩展和生产就绪的Java应用的创建,从而彻底改变了Java开发。 它的“惯例惯例”方法(春季生态系统固有的惯例),最小化手动设置
