Advertisement
Georgi_Benchev

Untitled

Dec 2nd, 2024
74
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 3.37 KB | None | 0 0
  1. package set_and_Map_CodingTasks_1;
  2.  
  3. import java.util.*;
  4. import java.util.stream.Collectors;
  5.  
  6. public class Inventory_Manager {
  7.     public static void main(String[] args) {
  8.         Scanner scanner = new Scanner(System.in);
  9.  
  10.  
  11.         String input;
  12.         Map<String, Double> inventoryPrices = new TreeMap<>();
  13.         Map<String, String> inventoryTypes = new TreeMap<>();
  14.  
  15.  
  16.         while (!"end".equals(input = scanner.nextLine())) {
  17.             ArrayList<String> inputLine = Arrays.stream(input.split(" "))
  18.                     .collect(Collectors.toCollection(ArrayList::new));
  19.             String command = inputLine.get(0);
  20.  
  21.             if (command.equals("add")) {
  22.                 String itemName = inputLine.get(1);
  23.                 Double itemPrice = Double.parseDouble(inputLine.get(2));
  24.                 String itemType = inputLine.get(3);
  25.                 if (inventoryPrices.containsKey(itemName)) {
  26.                     System.out.printf("Error: Item %s already exists%n", itemName);
  27.                 } else {
  28.                     inventoryPrices.put(itemName, itemPrice);
  29.                     inventoryTypes.put(itemName, itemType);
  30.                     System.out.printf("Ok: Item %s added successfully%n", itemName);
  31.                 }
  32.  
  33.             } else if (command.equals("filter")) {
  34.                 String filtrationType = inputLine.get(2);
  35.  
  36.                 if (filtrationType.equals("price")) {
  37.                     String priceType = inputLine.get(3);
  38.  
  39.                     if (priceType.equals("to")) {
  40.                         Double maxPrice = Double.parseDouble(inputLine.get(4));
  41.  
  42.                         List<String> output = new ArrayList<>();
  43.  
  44.  
  45.                         inventoryPrices.entrySet().stream()
  46.                                 .filter(e -> e.getValue() <= maxPrice)
  47.                                 .limit(10)
  48.                                 .forEach(e -> {
  49.                                     output.add(String.format("%s (%.2f)", e.getKey(), inventoryPrices.get(e.getKey())));
  50.                                 });
  51.                         StringBuilder sb = new StringBuilder();
  52.                         sb.append("OK: ");
  53.                         sb.append(String.join(", ", output));
  54.                         System.out.println(sb);
  55.  
  56.                     } else {
  57.  
  58.                     }
  59.  
  60.                 } else if (filtrationType.equals("type")) {
  61.                     String typeToFilter = inputLine.get(3);
  62.  
  63.                     List<String> output = new ArrayList<>();
  64.                     if (!inventoryTypes.containsValue(typeToFilter)) {
  65.                         System.out.printf("Error: Type %s does not exist%n", typeToFilter);
  66.                     } else {
  67.                         inventoryTypes.entrySet().stream()
  68.                                 .filter(e -> e.getValue().equals(typeToFilter))
  69.                                 .limit(10)
  70.                                 .forEach(e -> {
  71.                                     output.add(String.format("%s (%.2f)", e.getKey(), inventoryPrices.get(e.getKey())));
  72.                                 });
  73.                         StringBuilder sb = new StringBuilder();
  74.                         sb.append("OK: ");
  75.                         sb.append(String.join(", ", output));
  76.                         System.out.println(sb);
  77.                     }
  78.                 }
  79.             }
  80.  
  81.  
  82.         }
  83.  
  84.     }
  85. }
  86.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement