首页 >Java >java教程 >Java枚举的使用方式和算法介绍

Java枚举的使用方式和算法介绍

王林
王林转载
2023-04-23 08:19:06986浏览

想要使用枚举算法,首先要确定枚举对象、枚举范围和判定条件逐一枚举可能的解,验证每个解是否是问题的解,千万不要漏掉任何一个可能正确的解。

举个栗子

百钱买百鸡问题:有一个人有一百块钱,打算买一百只鸡。到市场一看,大鸡三块钱一只,小鸡一块钱三只,不大不小的鸡两块钱一只。现在,请你编一程序,帮他计划一下,怎么样买法,才能刚好用一百块钱买一百只鸡?

我们可以设公鸡为x,母鸡为y,小鸡为z,可以得出下列方程: 
       x + y +z=100; 
       5x + 3y + z/3 = 100; 现在只要穷举每一个 公鸡的值,母鸡,小鸡的值         就能通过公鸡的 x 表示出来。

代码:

Java枚举算法怎么使用

图中代码使用了三次for循环 时间复杂度(不知道的不用担心后期会专门出文章来讨论) 为O(N^3); 我们都喜欢一个程序简便,不消耗空间,短小精悍,看着高端的那种。下面介绍优化。

优化套路

虽然枚举是一种很暴利的算法,但是仍可以通过缩小枚举范围提高解决问题的效率。同时也要避免重复枚举

来看第二种方式:

x+y+z = 100      ①

5x+3y+z/3 = 100  ②

令②x3-① 可得

7x+4y = 100

=>y = 25-(7/4)x       ③

又因为0 < y < 100 的自然数,则可令

x = 4k ④

将④代入③可得

=> y = 25-7k     ⑤

将④⑤代入①可知

=> z = 75+3k    ⑥

要保证 0 < x,y,z < 100 的话,k的取值范围只能是1,2,3 

代码:

Java枚举算法怎么使用

这个代码就达到了一层循环的基础,时间复杂度为 O(n);

这个栗子介绍了枚举优化的一种套路就是减少枚举的变量。整个优化枚举的套路主要是有两个方面一个是减少枚举变量,一个是缩小枚举范围。

以上是Java枚举的使用方式和算法介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:yisu.com。如有侵权,请联系admin@php.cn删除