Compare commits

...

5 Commits

Author SHA1 Message Date
d8bd33e6d1 Merge remote-tracking branch 'origin/master' 2022-12-09 14:19:02 +01:00
3c28114bd5 fixed interface implementation 2022-12-09 14:18:16 +01:00
Johannes Kantz
998d8aefd7 add: Readme mit Teilnehmerliste 2022-12-09 14:18:06 +01:00
Johannes Kantz
f85e17a726 add: GebietsDateiInterface 2022-12-09 14:10:55 +01:00
3f42a3aca5 Merge pull request '42' (#13) from fix/all into master
Reviewed-on: #13
2022-12-09 14:00:38 +01:00
6 changed files with 37 additions and 10 deletions

13
README.md Normal file
View File

@ -0,0 +1,13 @@
# G91_Einkommen
Entwickeln Sie ein Java Programm zur Anzeige des gebietsabhängigen Durchschnittseinkommens von Bundesbürgern auf der Konsole.
## Beteiligte
- Jan-Philipp Schulte
- Malte Schulze Hobeling
- Reshad Meher
- Richard Reiswich
- Johannes Kantz
[GitTea Repo](https://git.bib.de/Homeoffice/passivesEinkommen)

View File

@ -9,13 +9,13 @@ public class EinkommenInfo {
GebietsListe gebietsListe = new GebietsListe(gebiet); GebietsListe gebietsListe = new GebietsListe(gebiet);
System.out.println(gebietsListe.getAnzahlGesamt() + " Gebiete wurden eingelesen."); System.out.println(gebietsListe.getAnzahlGesamt() + " Gebiete wurden eingelesen.");
System.out.println(gebietsListe.getAnzahlUnvollstaendig() + " davon haben unvollständige Angaben.\n"); System.out.println(gebietsListe.getAnzahlUnvollständig() + " davon haben unvollständige Angaben.\n");
System.out.println("Gebiet mit dem geringsten Durchschnittseinkommen:"); System.out.println("Gebiet mit dem geringsten Durchschnittseinkommen:");
System.out.println(gebietsListe.getGebietMinDurchschnittEinkommen()); System.out.println(gebietsListe.getGebietMinDurchschnittsEinkommen());
System.out.println("Gebiet mit der größten Einwohernzahl:"); System.out.println("Gebiet mit der größten Einwohernzahl:");
System.out.println(gebietsListe.getGebietMaxEinwohner()); System.out.println(gebietsListe.getGebietMaxAnzahlEinwohner());
Scanner sc = new Scanner(System.in); Scanner sc = new Scanner(System.in);
while (true) { while (true) {
@ -24,7 +24,7 @@ public class EinkommenInfo {
if (input.isEmpty()) { if (input.isEmpty()) {
break; break;
} }
List<Gebiet> foundAreas = gebietsListe.getGebietNachNamen(input); List<Gebiet> foundAreas = gebietsListe.getGebieteNachNamen(input);
for (Gebiet area : foundAreas) { for (Gebiet area : foundAreas) {
System.out.println(area); System.out.println(area);
} }

View File

@ -0,0 +1,5 @@
import java.util.ArrayList;
public interface GebiesDateiInterface {
ArrayList<Gebiet> getGebiete();
}

View File

@ -2,7 +2,7 @@ import java.nio.file.Files;
import java.nio.file.Paths; import java.nio.file.Paths;
import java.util.ArrayList; import java.util.ArrayList;
public class GebietsDatei { public class GebietsDatei implements GebiesDateiInterface {
private String dateiName; private String dateiName;

View File

@ -1,21 +1,21 @@
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
public class GebietsListe { public class GebietsListe implements GebietsListeInterface{
private List<Gebiet> gebiete = new ArrayList<>(); private List<Gebiet> gebiete = new ArrayList<>();
public GebietsListe(List<Gebiet> gebiete) { public GebietsListe(List<Gebiet> gebiete) {
this.gebiete = gebiete; this.gebiete = gebiete;
} }
public Gebiet getGebietMinDurchschnittEinkommen() { public Gebiet getGebietMinDurchschnittsEinkommen() {
return gebiete.stream() return gebiete.stream()
.filter(g -> g.getDurchschnittsEinkommen() != -1) .filter(g -> g.getDurchschnittsEinkommen() != -1)
.min((g1, g2) -> g1.getDurchschnittsEinkommen() - g2.getDurchschnittsEinkommen()) .min((g1, g2) -> g1.getDurchschnittsEinkommen() - g2.getDurchschnittsEinkommen())
.get(); .get();
} }
public Gebiet getGebietMaxEinwohner() { public Gebiet getGebietMaxAnzahlEinwohner() {
return gebiete.stream() return gebiete.stream()
.filter(g -> g.getDurchschnittsEinkommen() != -1) .filter(g -> g.getDurchschnittsEinkommen() != -1)
.max((g1, g2) -> g1.getAnzahlEinwohner() - g2.getAnzahlEinwohner()) .max((g1, g2) -> g1.getAnzahlEinwohner() - g2.getAnzahlEinwohner())
@ -26,13 +26,13 @@ public class GebietsListe {
return gebiete.size(); return gebiete.size();
} }
public int getAnzahlUnvollstaendig() { public int getAnzahlUnvollständig() {
return (int) gebiete.stream() return (int) gebiete.stream()
.filter(g -> g.getDurchschnittsEinkommen() == -1 || g.getGesamtEinkommen() == -1) .filter(g -> g.getDurchschnittsEinkommen() == -1 || g.getGesamtEinkommen() == -1)
.count(); .count();
} }
public List<Gebiet> getGebietNachNamen(String namensanfang) { public List<Gebiet> getGebieteNachNamen(String namensanfang) {
return gebiete.stream() return gebiete.stream()
.filter(g -> g.getName().startsWith(namensanfang)) .filter(g -> g.getName().startsWith(namensanfang))
.toList(); .toList();

View File

@ -0,0 +1,9 @@
import java.util.List;
public interface GebietsListeInterface {
Gebiet getGebietMinDurchschnittsEinkommen();
Gebiet getGebietMaxAnzahlEinwohner();
int getAnzahlGesamt();
int getAnzahlUnvollständig();
List<Gebiet> getGebieteNachNamen(String namensanfang);
}