Wenn dein Problem oder deine Frage geklärt worden ist, markiere den Beitrag als "Lösung",
indem du auf den "Lösung" Button rechts unter dem entsprechenden Beitrag klickst. Vielen Dank!
Moin!
Vielleicht bin ich gerade zu vernagelt, aber ich finde keine Lösung:
Ich vergleiche zwei Zahlen (Fließkomma) und will in Abhängigkeit davon einen Case auswählen. Die drei Fälle sind A<B, A>B, A=B.
Ich kann jetzt natürlich dreimal nen Vergleich machen und drei true-false-Cases einbauen, aber ich wollte das elegant in einer Case-Struktur lösen. Nur klappt das nich so recht. Ich dachte mir, ich nehme die beiden Zahlen, ziehe sie voneinander ab und dann habe ich ja die Fälle "kleiner Null", "Null" und "größer Null". Ich kann aber in der Case-Struktur nur "..-1", "0", und "1.." eingeben. Da die Zahlen relativ kleine Kommazahlen sind, liegen die meisten zwischen Null und Eins.
Alle Möglichkeiten, die ich bis jetzt probiert hab, klappen nich.. ich hätte da halt gerne "<0", "0" und ">0" drinstehen, aber sowas wandelt LV in Strings um..
Ich hab so das Gefühl, als müsste das sehr einfach gehen, ist doch eigentlich ein gängiger Fall so ne Überprüfung.. ich glaub, ich geh jetzt erstmal eben Mittagessen, vielleicht kann ich danach auch wieder klar denken *g*
du wirst so oder so nicht um mindestens 2 Vergleiche herumkommen, da ein Vergleich ja nur True-False als Ausgabe hat, du aber 3 Cases haben willst.
Also Möglichkeit 1: 2 ineinanderverschachtelte Case-Strukturen, in der äußeren wird z.B. > Case und <= Case behandelt, im <= Case kommt dann eine weitere Case-Struktur, in der du dann = (Vorsicht mit dem = bei Float-Zahlen) und < behandelst.
Möglichkeit 2: Vor der Case-Struktur 2 Vergleiche, einmal > und einmal <. Dann aus diesen beiden Vergleichen irgendwie geschickt deine 3 Fälle zusammenbasteln, wobei du als Ausgang eine Integer-Variable brauchst. Aber da müsste ich erst mal die kleinen grauen Zellen anwerfen, und dazu fehlt mir momentan die Zeit.
Also, schneller ist auf jeden Fall Variante 1.
MfG, Jens
Wer die erhabene Weisheit der Mathematik tadelt, nährt sich von Verwirrung. (Leonardo da Vinci)
!! BITTE !! stellt mir keine Fragen über PM, dafür ist das Forum da - andere haben vielleicht auch Interesse an der Antwort!
ja, danke, genau sowas wollte ich haben! :-)
hätte ich auch drauf kommen können, dass man sich das selber basteln muss, anstatt das direkt so eingeben zu können.. manchmal denke ich noch zu sehr in klassischen programmiersprachen *g*
' schrieb:ja, danke, genau sowas wollte ich haben! :-)
hätte ich auch drauf kommen können, dass man sich das selber basteln muss, anstatt das direkt so eingeben zu können.. manchmal denke ich noch zu sehr in klassischen programmiersprachen *g*
Hi,
wär doch noch einfacher gegangen. Beide Zahlen von einander abziehen und dann die sign- funktion, dann hat man als ausgang -1,0,1 genau das was gewollt war.
mfg jeffrey
' schrieb:Alle Möglichkeiten, die ich bis jetzt probiert hab, klappen nich.. ich hätte da halt gerne "<0", "0" und ">0" drinstehen, aber sowas wandelt LV in Strings um..
Das ginge prinzipiell so: "..-1" oder "0" oder "1.."...geht halt leider nur mit Integers...
Gruß
Achim
"Is there some mightier sage, of whom we have yet to learn?"
"Opportunity is missed by most people because it is dressed in overalls and looks like work." (Thomas Edison)
' schrieb:Hi,
wär doch noch einfacher gegangen. Beide Zahlen von einander abziehen und dann die sign- funktion, dann hat man als ausgang -1,0,1 genau das was gewollt war.
mfg jeffrey
stimmt, das is auch nich schlecht. werd ich mir mal merken, hier kommts nich auf ein paar millisekunden laufzeit an, aber vielleicht ja irgendwann mal schon :-)
' schrieb:Das ginge prinzipiell so: "..-1" oder "0" oder "1.."...geht halt leider nur mit Integers...
Gruß
Achim
ja, genau das war das problem, ich habe eben keine integer.. aber inzwischen läufts ja wunderbar, danke nochmal! :-)