哪种数据结构最适合诸如 Item can not be Shiped to a ZipCode 之类的规则

问题描述

我有一个运输限制表,其中包含以下规则:
产品类别:“套房”不能运送到“格鲁吉亚”,
ProductClass:'Body Spray' 和 Hazmat:True 不能运送到 Postal Code:322001
产品类别:“婴儿玩具”不能运送到“美国”,
我们有一个规则,例如,我不能将任何物品运送到“亚利桑那州”。

ProductClass、Hazmat 和 ShippingMethod 是一组(零个或多个属性可以有值)。
同样的方式邮政编码,州,国家是另一组(每个规则只会填充一个值)。
这是配置/静态数据,它会很大(超过 10k 条规则)

RuleId 产品类别 危险品 发货方式 邮政编码 状态 国家
1 西装 格鲁吉亚
2 身体喷雾 真的 322001
3 身体喷雾 322009
4 婴儿玩具 美国
5 佛罗里达
6 空气 夏威夷
7 亚利桑那州

现在我收到了 3 件商品的订单,例如:
项目 1:产品类别“A”,危险品:假,运输方式:“ByAir”,邮政编码:322002,状态:“德克萨斯”
项目 2:产品类别“E”,危险品:假,运输方式:“ByAir”,邮政编码:322009,状态:“德克萨斯”
Item3:产品类别“D”,危险品:假,运输方式:“ByAir”,邮政编码:322011,州:“佛罗里达”

当我收到订单时(在我的示例中,我收到了 3 件商品的订单),我需要运行上面配置的所有这些限制规则,如果某个商品有一个/多个限制规则匹配,则需要记录它们。

在 Java 中实现这一目标的最佳算法是什么。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)