У меня есть List
цен и ценовых групп.
static class PriceGroup {
String priceName;
String priceGroup;
}
static class Price {
String priceName;
Integer price;
}
Ниже приведены некоторые примеры данных и одна реализация, которую я написал, чтобы найти самую низкую цену для каждой PriceGroup. Любые предложения, как я мог бы реорганизовать это, чтобы использовать потоки для объединения этих данных?
List<PriceGroup> priceGroups = Arrays.asList(
new PriceGroup("F1", "Friends"),
new PriceGroup("F2", "Friends"),
new PriceGroup("O1", "Others"),
new PriceGroup("O2", "Others"));
List<Price> prices = Arrays.asList(
new Price("F1", 100),
new Price("F2", 150),
new Price("O1", 250),
new Price("O2", 300));
public Map<String, Integer> getBestPrices(List<PriceGroup> priceGroups, List<Price> prices)
{
Map<String, Integer> bestPrice = new HashMap<String, Integer>();
for (PriceGroup priceGroup : priceGroups) {
if (bestPrice.get(priceGroup.priceGroup) == null) {
bestPrice.put(priceGroup.priceGroup, 10000000);
}
for (Price price : prices) {
if (price.priceName.equals(priceGroup.priceName)) {
bestPrice.put(priceGroup.priceGroup, Math.min(price.price, bestPrice.get(priceGroup.priceGroup)));
}
}
}
return bestPrice;
}
Для заданных данных моя функция должна вернуть карту с:
F1 => 100
O1 => 250