Methode Implementieren

TheBeginner

Mitglied
Implementieren Sie in der Programmiersprache Java eine Methode mit der Bezeichnung smallestPositiveInteger, die aus einem übergebenen ganzzahligen Array den kleinsten positiven Eintrag bestimmt und diesen zurückgibt. Enthält das übergebene Array keinen positiven Eintrag, so ist der Rückgabewert der Methode 0.



public static int smallestPositiveNumber( int[] vector) {

int temp = 0;

for (int entry : vector) {
if (entry > 0 && (temp == 0 || entry < temp)){
temp = entry;
}
}
return temp;
}


Hallo Zusammen,

ich komm mit dieser Lösung leider nicht klar. Ich verstehe nicht, was das sein soll

(temp == 0 || entry < temp)


Hätte jmd. von euch ein alternativen Lösungsweg ?

Danke im Voraus
 

TheBeginner

Mitglied
public static int smallestPositiveNumber( int[] vector) {

int temp = 0;

for (int entry : vector) {
if (entry > 0 && (temp == 0)){ // Haben wir folgendes da stehen, betrachten wir auf jedenfall nur die positiven Zahlen.
temp = entry;
}
}
return temp;
}


z.B int[] vektor = {-5,2,1,5}

Aber damit würd ich nicht den allerkleinsten positiven ganzzahligen Array bekommen, sonder 2,1,5 oder ??

Mir ist nicht klar, wie ich an den kleinsten ganzzahligen Array komme.
 

Michael...

Top Contributor
Aber damit würd ich nicht den allerkleinsten positiven ganzzahligen Array bekommen, sonder 2,1,5 oder ??

Mir ist nicht klar, wie ich an den kleinsten ganzzahligen Array komme.
Was ist ein "kleinster ganzzahliger Array"? Es geht hier um den kleinsten ganzzahligen Eintrag im Array.
Den Code schon mal ausgeführt und mit Deinem Bsp. getestet? Dann wüsstest Du, ob die Lösung funktioniert. Oder macht Ihr die Hausaufgaben nur theoretisch und auf Papier?
 

TheBeginner

Mitglied
temp wird doch schon oben der Wert 0 zugewiesen. Das wurd doch oben so definiert. Wieso schreibt man das nochmals auf ?

Und entry kann doch nicht < temp sein.


Das habe ich doch in der ersten Bed. festgelegt:

Da : if (entry > 0......

Wenn das nicht gilt, wird doch die if-Bed. gar nicht weiter betrachtet.
 

TheBeginner

Mitglied
Nur auf Papier.

Der kleinste positive Eintrag, ist meiner Meinung nach ein Eintrag von dem übergebenen Array.

Bsp. int[]array= {-6,2,4,5}

Hier wäre also 2 der kleinste pos. Eintrag im Array
 

Michael...

Top Contributor
temp kann sich aber während den Schleifendurchgängen verändern (
Code:
temp=entry
). Schließlich soll temp am Ende der Schleife den kleinsten positiven Eintrag enthalten.

Nimm doch mal Dein Bsp Array und schreibe Dir das Ergebnis des Vergleichs und den Zustand jeder Variablen bei jedem Schleifendurchgang auf.
 

TheBeginner

Mitglied
Ich beschäftige mich schon seit Tagen mit diesen Code, um komm da nicht voran.

Mein Problem ist nach wie vor dasselbe:
Java:
public static int smallestPositiveNumber( int[] vector) {

int temp = 0;

for (int entry : vector) {

if (entry > 0 && (temp == 0 || entry < temp))
temp = entry;
}
}
return temp;
}
für das Bsp. : int[ ] vektor = {-6,2,4,5}

Wird die if-Bed. nicht ausgeführt für -6, da entry<0

Für die restlichen allerdings 2,4,5 wird die Schleife jeweils durchgeführt. da temp==0, obwohl entry nicht < temp ist, denn dann müsste entry negativ sein.

Beim logischen Oder- reicht es das eine Bed. wahr ist.

Nach meinem Verständnis müsste also:

temp beim ersten Schleifendurchlauf den Wert 2 haben
temp beim zweiten Schleifendurchlauf den Wert 4 haben ( temp wird überschrieben !! )
mp beim dritten Schleifendurchlauf den Wert 5 haben ( wird erneut überschrieben !! )

Das hieße , das der Wert der zurückgegeben wird 5 ist.

Und das kann ja nicht sein. Da sonst die Musterlösung falsch ist. Ich bitte um ausführliche Erklärung, um das abzuhaken. Habe noch eine ähnliche Aufgabe und würd die gerne danach machen.
Wie gesagt ich bin Beginner, und bin an eure Hilfe angewiesen.

Danke im Voraus
 

timbeau

Gesperrter Benutzer
Hast du den Code mal laufen lassen?

Du kannst ja auch die Werte seperat berechnen.

ABER: sobald temp den Wert 2 hat ist WEDER temp==0 NOCH entry < temp!

Damit ist entry > 0 = true ABER der 2. Ausdruck false

>> true && false = false >> temp bleibt bei 2
 

Paddelpirat

Bekanntes Mitglied
Beispiel int[ ] vektor = {-6,2,4,5}

Ausgangssituation:
temp = 0; entry = -6;

enty < 0 also passiert nichts.

nächster Schritt:
temp = 0; entry = 2;

entry > 0 ist wahr, also teste weiter (temp == 0 || entry < temp)
temp == 0 ist wahr, also wird temp = entry gesetzt.

Es gilt nun temp = 2; entry = 2

Nächster Schritt:
temp = 2; entry = 4;

entry > 0 ist wahr, also teste weiter (temp == 0 || entry < temp)
temp == 0 ist unwahr und entry < temp ist auch unwahr
Also passiert nichts.

usw. ;-)
 

Michael...

Top Contributor
Kannst Du mal Java Tags benutzten, dann wird er Code hier auch übersichtlicher dargestellt.
temp beim zweiten Schleifendurchlauf den Wert 4 haben ( temp wird überschrieben !! )
mp beim dritten Schleifendurchlauf den Wert 5 haben ( wird erneut überschrieben !! )
Sicher? temp wird ja nur unter bestimmten Umständen überschrieben.
Wenn man das am Code nicht erkennt, hilft es echt sich die Variablenzustände für jeden Schleifendurchgang aufzuschreiben.
Java:
int[ ] vektor = {-6,2,4,5};
int temp = 0;
Erster Schleifendurchgang:
Code:
entry = - 6
und
Code:
temp=0
Code:
(entry > 0 && (temp == 0 || entry < temp))
liefert false da
Code:
entry < 0
Zweiter Schleifendurchgang:
Code:
entry = 2
und
Code:
temp=0
Code:
entry > 0
trifft zu und
Code:
(temp == 0 || entry < temp)
ebenfalls, da
Code:
temp==0
Daher wird
Code:
 temp = entry
also
Code:
temp=2
gesetzt.
Dritter Schleifendurchgang:
Code:
entry = 4
und
Code:
temp=2
Code:
entry > 0
trifft zu. Aber wie schaut es hiermit aus?
Code:
(temp == 0 || entry < temp)
 

X5-599

Top Contributor
Als ich sehe das so:

bsp: int[ ] vektor = {-6,2,4,5}


erster durchlauf:
entry (-6) ist nicht grösser 0 also ist diese Bedingung nicht erfüllt. Etwas anderes wird nicht mehr überprüft. Durchgang beendet.

zweiter durchlauf:
entry (2) ist grösser 0 also ist diese Bedingung schonmal erfüllt. entry ist nicht kleiner temp (temp ist noch 0) aber temp ist gleich 0, also ist diese Bedingung ebenfalls erfüllt. Darum wird nun entry temp zugewiesen. temp ist nun (2).

dritter durchgang:
entry (4) ist grösser 0 also ist diese Bedingung schonmal erfüllt. entry ist nicht kleiner temp (2). Auch ist temp nicht gleich 0. (temp wird niemals mehr 0 sein). Die zweite Bedingung ist also nicht erfüllt. Durchgang beendet.

vierte durchgang:
entry (5) ist grösser 0 also ist diese Bedingung schonmal erfüllt. entry ist nicht kleiner temp (immernoch 2). Auch ist temp nicht gleich 0. (temp wird niemals mehr 0 sein). Die zweite Bedingung ist also nicht erfüllt. Durchgang beendet.


Also:
Der Vergleich temp == 0 kommt nur vor damit der erste gefundene Wert, der grösser als 0 ist in temp geschrieben werden darf. Danach kann temp niemals mehr 0 sein! Mit entry kleiner als temp wird dann überprüft ob der aktuelle (positive) entry Wert noch kleiner ist als der bisher gefundene (temp).

Ich hoffe ich habe mich nicht zu unverständlich ausgedrückt.
Gruß,
X5
 

TheBeginner

Mitglied
So ich danke euch Allen vielmals.


Also wenn so viel Wissen hinter dieser Aufgabe steht, dann find ich, das schon schwer so ne Bedingung aufzuschreiben, oder findet ihr nicht ?

Wie geht ihr generell an so einer Aufgabe dran, wo die Bedingung etwas umfangreicher ist ??
 

timbeau

Gesperrter Benutzer
Hmm, ich finde irgendwann ist eine boolsche-Verknüpfung zu unübersichtlich. Diese geht noch.

Man könnte aber noch eine weitere Vorverzweigung einbauen
Java:
if(entry > 0) {
          if(temp == 0 || entry < temp) {

    }
Das macht insofern Sinn, wenn die 2. Bedinung lange dauern würde zu überprüfen wie:

Java:
 if(datenbankeintraegeMitAnfangsbuchstabe(String "X") > 200) //lange Methode
Aber wenn du mit Java weiter bist, ist das ziemlich einfach. Da kommen ganz andere Sachen
 

Michael...

Top Contributor
Wie geht ihr generell an so einer Aufgabe dran, wo die Bedingung etwas umfangreicher ist ??
Unabhängig, ob es sich um eine Bedingung oder sonstigen Code handelt, hilft es den Code in einzelnen Schritten zu "durchschreiten".

Im Falle von
Code:
(entry > 0 && (temp == 0 || entry < temp))
hilft zunächst die Vergleiche einzeln "auszuwerten" und Stück für Stück wieder zusammenzusetzen
Bsp
Code:
entry=2
und
Code:
temp=0
Code:
entry > 0
=> true
Code:
temp == 0
=> true
Code:
entry < temp
=> false

Code:
temp == 0 || entry < temp
=>
Code:
true || false
=> true

Code:
(entry > 0 && (temp == 0 || entry < temp))
=>
Code:
true && true
=> true
 

Paddelpirat

Bekanntes Mitglied
In der Schule haben wir solche Auswertungen immer mit Wertetabellen gemacht, in der du halt für jeden Schritt die aktuellen Werte der Variablen aufschreibst und anschließend die einzelnen Terme in der (if-) Abfrage auswertest. Wurde ja jetzt auch drei mal vorgeführt, wobei man das auf einem Blatt Papier bestimmt noch ansehnlicher notieren kann.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Wie kann ich eine Methode aus einem Interface in eine Klasse implementieren, so dass sie ihre Funktion ausführt? Java Basics - Anfänger-Themen 7
T Methode implementieren Java Basics - Anfänger-Themen 21
L Methode implementieren, Parameter die übergeben werden sind final Java Basics - Anfänger-Themen 4
C Zyklisch verkette Liste - Pop() methode implementieren Java Basics - Anfänger-Themen 2
T Equal Methode implementieren Java Basics - Anfänger-Themen 22
S Generische Methode soll Objekte als Parameter erlauben die bestimmtes Interface implementieren^ Java Basics - Anfänger-Themen 9
G Erbklasse verpflichten Methode zu implementieren Java Basics - Anfänger-Themen 3
T Methoden Wie compareTo() Methode implementieren? Java Basics - Anfänger-Themen 9
T Rekursive Methode Java Basics - Anfänger-Themen 13
Ü Methode soll Quadrat aus der Summer zurückgeben Java Basics - Anfänger-Themen 10
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
Leyla Spezifischte Methode Java Basics - Anfänger-Themen 16
M Methode zielnah zeigt das gewünschte Ausgabe nicht an Java Basics - Anfänger-Themen 3
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
P Main Methode scheint Constructor aufzurufen, ohne dass es so gecoded ist Java Basics - Anfänger-Themen 2
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
C Zugriff auf Methode Java Basics - Anfänger-Themen 2
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
M Methode sperren bis ein Kriterium erfüllt wurde Java Basics - Anfänger-Themen 3
D Switch Case Methode aufrufen Java Basics - Anfänger-Themen 3
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
M methode aufrufen ohne parameter Java Basics - Anfänger-Themen 1
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
Ostkreuz Wieso wird die Methode nochmal aufgerufen? Java Basics - Anfänger-Themen 5
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
Say super.methode / super.variable und super(variable) Java Basics - Anfänger-Themen 2
B Wie kann ich folgende Klasse/Methode per Button ausführen? Java Basics - Anfänger-Themen 1
D Interface Methode wird ungewollt in der Subklasse überschrieben Java Basics - Anfänger-Themen 5
L Methoden Eine Methode um zu testen ob es ein Nachbar gibt Java Basics - Anfänger-Themen 10
til237 Iterative Methode in rekursive Methode umschreiben Java Basics - Anfänger-Themen 4
M Daten aus errechneter Methode in Datenbank(SQLite) schreiben Java Basics - Anfänger-Themen 60
D next() Methode mehrfach verwenden Java Basics - Anfänger-Themen 1
Ostkreuz Methoden Von Dezimal zu Hexadezimal Methode toHex Java Basics - Anfänger-Themen 2
I Entity Objekt nicht gefunden -> Webhook empfangen in der gleichen Methode (Transaktion) Java Basics - Anfänger-Themen 37
N Throw an Main Methode übergeben Java Basics - Anfänger-Themen 7
M Methoden Methode 'wiederhole' nicht gefunden (Uebersetzungsfehler) Java Basics - Anfänger-Themen 1
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
M Anzahl Kommandozeilenparamter mittels Methode Java Basics - Anfänger-Themen 11
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
frager2345 Problem mit Methode Java Basics - Anfänger-Themen 4
J Die statische Main-Methode ändert Instanzvariable? Java Basics - Anfänger-Themen 10
D Methode aus dem Aufrufer aufrufen Java Basics - Anfänger-Themen 1
T IOStreams read(byte[]b) methode Java Basics - Anfänger-Themen 2
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
U Beispiel Methode size() vom "Collection"-interface... Wie kann man sichtbar machen, was die Methode unter der Haube macht? Java Basics - Anfänger-Themen 8
D Warum kann ich hier nicht auf die Methode zugreifen? Java Basics - Anfänger-Themen 5
M generate Methode für Streams Java Basics - Anfänger-Themen 6
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
I Optionaler Parameter bei Methode, der nur optional ist? Java Basics - Anfänger-Themen 6
berserkerdq2 Wozu benötigt man den BiPredicate, kann ich nicht einfach eine normale Methode nutzen, statt BiPredicate? Java Basics - Anfänger-Themen 3
T Linked List set-Methode Java Basics - Anfänger-Themen 2
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
W Equals-Methode überschreiben bei composition Java Basics - Anfänger-Themen 20
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
V Methoden printChar Methode mit Rückgabetyp void Java Basics - Anfänger-Themen 26
F Graph Tiefensuche Methode Java Basics - Anfänger-Themen 7
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
berserkerdq2 wie funktioniert contenthandler, was muss ich bei der Methode startElement und endElement tun? Java Basics - Anfänger-Themen 11
M Warum return die Methode den Wert nicht Java Basics - Anfänger-Themen 5
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
S Methode Java Basics - Anfänger-Themen 4
M Eine Methode die erkennt ob die ein gegebene zahl größer oder kleiner sein muss Java Basics - Anfänger-Themen 2
U Methode wird genutzt, ohne dass ich die aufrufe? Java Basics - Anfänger-Themen 4
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
Liroyd Methode mit Objektvariabel rechnen? Java Basics - Anfänger-Themen 6
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
D Methode um mögliche Rezepte auszugeben Java Basics - Anfänger-Themen 12
U Warum kann ich die Methode in der ENUM Klasse nicht aufrufen? Und warum geht die Switch nicht? Java Basics - Anfänger-Themen 8
J Hallo zusammen , was macht diese Methode hier genau? Java Basics - Anfänger-Themen 3
D Array in Main Methode aus anderer Klasse aufrufen Java Basics - Anfänger-Themen 3
H Eine Methode über Actionlistener beenden Java Basics - Anfänger-Themen 8
G jButton führt Main Methode nicht richtig aus Java Basics - Anfänger-Themen 3
G Main Methode wird beim ersten Aufruf nicht richtig ausgeführt Java Basics - Anfänger-Themen 1
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
L Iteratorform und Methode mit variabler Parameterzahl Java Basics - Anfänger-Themen 31
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
Csircc Rekursive Methode Stack Overflow Java Basics - Anfänger-Themen 10
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
M Wie kann eine Methode eine andere Methode um Werte wie z.B. 1 erhöhen? Java Basics - Anfänger-Themen 6
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben