Yargi

SoftUniCoursePlanning

Jun 22nd, 2020
100
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 3.06 KB | None | 0 0
  1. import java.util.ArrayList;
  2. import java.util.Arrays;
  3. import java.util.List;
  4. import java.util.Scanner;
  5.  
  6. public class SoftUniCoursePlanning {
  7.     public static void main(String[] args) {
  8.         Scanner sc = new Scanner(System.in);
  9.         List<String> schedule = new ArrayList<>();
  10.         Arrays.asList(sc.nextLine().split(", ")).stream().distinct().forEach(schedule::add);
  11.  
  12.         String command = "";
  13.         while (!"course start".equals(command = sc.nextLine())){
  14.  
  15.             String[] token = command.split(":");
  16.             String exe = "-Exercise";
  17.             switch (token[0]){
  18.                 case "Add":
  19.                     if (!schedule.contains(token[1])){
  20.                         schedule.add(token[1]);
  21.                     }
  22.                     break;
  23.  
  24.                 case "Insert":
  25.                     if (!schedule.contains(token[1])){
  26.                         int index = Integer.parseInt(token[2]);
  27.                         if (index >= 0 && index < schedule.size()){
  28.                             schedule.add(index, token[1]);
  29.                         }
  30.                     }
  31.                     break;
  32.  
  33.                 case "Remove":
  34.                     if (schedule.contains(token[1])){
  35.                         schedule.remove(schedule.indexOf(token[1]));
  36.                     }
  37.                     if (schedule.contains(token[1] + exe)){
  38.                         schedule.remove(schedule.indexOf(token[1] + exe));
  39.                     }
  40.                     break;
  41.  
  42.                 case "Swap":
  43.                     if (schedule.contains(token[1]) && schedule.contains(token[2])) {
  44.                         int firstSwapIndex = schedule.indexOf(token[1]);
  45.                         int secondSwapIndex = schedule.indexOf(token[2]);
  46.                         schedule.set(secondSwapIndex, token[1]);
  47.                         schedule.set(firstSwapIndex, token[2]);
  48.                         if (schedule.contains(token[1] + exe)){
  49.                             schedule.remove(schedule.indexOf(token[1] + exe));
  50.                             schedule.add(schedule.indexOf(token[1]) + 1, token[1] + exe);
  51.                         }
  52.                         if (schedule.contains(token[2] + exe)){
  53.                             schedule.remove(schedule.indexOf(token[2] + exe));
  54.                             schedule.add(schedule.indexOf(token[2]) + 1, token[2] + exe);
  55.                         }
  56.                     }
  57.                     break;
  58.  
  59.                 case "Exercise":
  60.                     if (schedule.contains(token[1]) && !schedule.contains(token[1] + exe)){
  61.                         schedule.add(schedule.indexOf(token[1]) + 1, token[1] + "-Exercise");
  62.                     }
  63.                     else if (!schedule.contains(token[1] + exe)){
  64.                         schedule.add(token[1]);
  65.                         schedule.add(token[1] + exe);
  66.                     }
  67.                     break;
  68.  
  69.             }
  70.         }
  71.  
  72.         for (int i = 0; i < schedule.size(); i++){
  73.             System.out.printf("%d.%s%n", i + 1, schedule.get(i));
  74.         }
  75.     }
  76. }
Advertisement
Add Comment
Please, Sign In to add comment