From bcbbc1151cd953fdefe59cdcb2fda07112e04df4 Mon Sep 17 00:00:00 2001 From: s92374 Date: Sun, 1 Jun 2025 22:40:39 +0200 Subject: [PATCH 1/3] Update README.md --- README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/README.md b/README.md index 4d7633b..b826102 100644 --- a/README.md +++ b/README.md @@ -23,3 +23,5 @@ Happy to receive your pull requests! ## Contents: - [SWT - Useful Links: Refactoring Guru](/swt-useful-links/refactoring-guru.md) + +Danke für die hilfreichen Lektionen! From e1dca51bfc705b1124d01ba1809a358743a32e89 Mon Sep 17 00:00:00 2001 From: s92374 Date: Sun, 1 Jun 2025 22:42:56 +0200 Subject: [PATCH 2/3] Update Kirschkuchen-Rezept_20230607081818.txt --- .history/Kirschkuchen/Kirschkuchen-Rezept_20230607081818.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.history/Kirschkuchen/Kirschkuchen-Rezept_20230607081818.txt b/.history/Kirschkuchen/Kirschkuchen-Rezept_20230607081818.txt index d93ee73..1d7c2ef 100644 --- a/.history/Kirschkuchen/Kirschkuchen-Rezept_20230607081818.txt +++ b/.history/Kirschkuchen/Kirschkuchen-Rezept_20230607081818.txt @@ -25,4 +25,4 @@ Ist die Kirschensaison vorbei, kann man den Kuchen auch mit selbst Eingelegten K Schokoladenfans geben in den Teig noch etwas Kakaopulver. Should be tasty! - +It is! From e2ce70324ca7f5c34740033426cfa7bfb18da3fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alina=20Sa=C3=9Fe?= Date: Sun, 1 Jun 2025 23:00:20 +0200 Subject: [PATCH 3/3] =?UTF-8?q?Java-Zeitplaner=20hinzugef=C3=BCgt=20f?= =?UTF-8?q?=C3=BCr=20Pull=20Request?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- java-zeitplaner/src/DVC.java | 130 +++++++++++++++++++++++++++++++++++ 1 file changed, 130 insertions(+) create mode 100644 java-zeitplaner/src/DVC.java diff --git a/java-zeitplaner/src/DVC.java b/java-zeitplaner/src/DVC.java new file mode 100644 index 0000000..7b6c293 --- /dev/null +++ b/java-zeitplaner/src/DVC.java @@ -0,0 +1,130 @@ +import java.util.*; + +/** + * Beschreibung: ESA DVC + * + * @author Alina Saße + * @version 1.00, 06/2025 + */ +public class DVC { + + static class Aufgabe { + String name; + int geplanteMinuten; + int prioritaet; + long echteDauerMillis; // gemessene Zeit in Millisekunden + + Aufgabe(String name, int geplanteMinuten, int prioritaet) { + this.name = name; + this.geplanteMinuten = geplanteMinuten; + this.prioritaet = prioritaet; + this.echteDauerMillis = 0; + } + + int getEchteDauerInMinuten() { + return (int) (echteDauerMillis / 1000 / 60); + } + } + + public static void main(String[] args) { + Scanner scanner = new Scanner(System.in); + List aufgaben = new ArrayList<>(); + long pausenDauer = 0; + + System.out.print("Wie viele Stunden möchtest du lernen? "); + int stunden = scanner.nextInt(); + System.out.print("Wie viele Minuten zusätzlich? "); + int minuten = scanner.nextInt(); + int verbleibendeMinuten = stunden * 60 + minuten; + + scanner.nextLine(); // Scanner-Puffer leeren + + while (true) { + System.out.println("\nVerbleibende Zeit: " + verbleibendeMinuten / 60 + "h " + (verbleibendeMinuten % 60) + "min"); + + String frage = aufgaben.isEmpty() ? "Woran möchtest du dich zuerst setzen? " : "Was steht sonst noch auf dem Plan?"; + System.out.print(frage); + String name = scanner.nextLine(); + if (name.equalsIgnoreCase("ende")) break; + + System.out.print("Wie viele Minuten soll das dauern? "); + int geplanteMinuten = scanner.nextInt(); + scanner.nextLine(); + + if (geplanteMinuten > verbleibendeMinuten) { + System.out.println("⚠️ Achtung: Du überschreitest deine verfügbare Zeit!"); + } + + System.out.print("Wie wichtig ist diese Aufgabe? (1 = hoch, 2 = mittel, 3 = niedrig): "); + int prioritaet = scanner.nextInt(); + scanner.nextLine(); + + aufgaben.add(new Aufgabe(name, geplanteMinuten, prioritaet)); + verbleibendeMinuten -= geplanteMinuten; + } + + // Aufgaben sortieren nach Priorität + aufgaben.sort(Comparator.comparingInt(a -> a.prioritaet)); + + // 🎯 Echte Zeitmessung starten + System.out.println("\n⏱ Aufgabenbearbeitung beginnt. Drücke [Enter], wenn du bereit bist mit einer Aufgabe zu starten."); + Map fachzeiten = new HashMap<>(); + + for (Aufgabe a : aufgaben) { + System.out.println("\n▶️ Aufgabe: " + a.name + " (geplant: " + a.geplanteMinuten + " Min)"); + System.out.print("Drücke [Enter], um zu starten..."); + scanner.nextLine(); + long start = System.currentTimeMillis(); + + System.out.println("⏳ Aufgabe läuft... Bearbeite jetzt: " + a.name); + System.out.print("Drücke [Enter], wenn du fertig bist: "); + scanner.nextLine(); + + long ende = System.currentTimeMillis(); + a.echteDauerMillis = ende - start; + + // Summe nach Thema + fachzeiten.put(a.name, fachzeiten.getOrDefault(a.name, 0) + a.getEchteDauerInMinuten()); + + System.out.println("✅ Fertig! Dauer: " + a.getEchteDauerInMinuten() + " Minuten."); + + // Neue Pausen-Funktion + System.out.print("😌 Möchtest du eine Pause machen? (j/n): "); + String pauseAntwort = scanner.nextLine(); + if (pauseAntwort.equalsIgnoreCase("j")) { + System.out.print("Drücke [Enter], um die Pause zu starten..."); + scanner.nextLine(); + long pauseStart = System.currentTimeMillis(); + + System.out.println("🧘‍♂️ Pause läuft... Drücke [Enter], wenn du weitermachen möchtest."); + scanner.nextLine(); + + long pauseEnde = System.currentTimeMillis(); + long pauseDauerMillis = pauseEnde - pauseStart; + pausenDauer += pauseDauerMillis; + + System.out.println("☕️ Pause beendet! Dauer: " + (pauseDauerMillis / 1000 / 60) + " Minuten."); + } + + } + + // Ausgabe + System.out.println("\n📝 Zusammenfassung:"); + for (Aufgabe a : aufgaben) { + String prio = switch (a.prioritaet) { + case 1 -> "hoch"; + case 2 -> "mittel"; + case 3 -> "niedrig"; + default -> "unbekannt"; + }; + System.out.println("- [" + prio + "] " + a.name + ": " + a.getEchteDauerInMinuten() + " Minuten (geplant: " + a.geplanteMinuten + ")"); + } + + // 📊 Zeitübersicht nach Thema + System.out.println("\n📊 Zeitübersicht nach Thema (gemessen):"); + for (Map.Entry entry : fachzeiten.entrySet()) { + int min = entry.getValue(); + System.out.println("- " + entry.getKey() + ": " + min / 60 + "h " + (min % 60) + "min"); + } + } +}