IF-Abfrage
-
Das ist doch eine typische Übungsaufgabe bei dem man mit Hilfe einer Wahrheitstabelle, und Nutzung der disjunktiven bzw. konjunktiven Normalform die entsprechende Logik ausrechen kann bzw. soll. Dazu sollte man die De-morganschen Gesetze kennen.
Die disjunktive Normalform erhält man, in dem man die für jedes wahre Ergebnis die Eingänge „und“ verknüpft, die konjuktive Normalform erhält für jedes „falsche“ Ergebnis die Eingänge oder verknüpft. Die einzelnen Terme werden bei der disjunktiven Normalform „oder“ verknüpft, und für die konjunktive Normalform „und“ verknüpft.
Ich habe das jetzt für die disjunktive Normalform einmal ausgeführt (englische Schreibweise).
A B C D Ergebnis Min Term Max Term 0 0 0 0 0 0 0 0 1 1 0 0 1 0 1 0 0 1 1 0 0 1 0 0 1 0 1 0 1 0 0 1 1 0 0 0 1 1 1 1 1 0 0 0 1 1 0 0 1 0 1 0 1 0 0 1 0 1 1 1 1 1 0 0 0 1 1 0 1 1 1 1 1 0 1 1 1 1 1 0 Das ergibt dann für die disjunktive Normalform
Das ist nun mit Hilfe der Rechenregeln zu vereinfachen.
-
@john-0 sagte in IF-Abfrage:
Das ist nun mit Hilfe der Rechenregeln zu vereinfachen.
@tech-house schrieb:
Es dürfen nur drei Operatoren verwendet werden.
-
@john-0
BTW, warum denn eine Wahrheitstabelle nicht fest eincodieren? Ist ja relativ klein.#include <iostream> int main() { static constexpr bool Table[2][2][2][2] = { 0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0 }; bool a = true; bool b = false; bool c = true; bool d = true; std::cout << Table[a][b][c][d] << std::endl; return 0; }
-
@Quiche-Lorraine sagte in IF-Abfrage:
@john-0
BTW, warum denn eine Wahrheitstabelle nicht fest eincodieren? Ist ja relativ klein.Der Ansatz kommt aus der Digitalelektronik, d.h. man will die Schaltung mit NANDs oder NORs aufbauen bzw. mit VHDL o.ä. in einem FPGA umsetzen, weil man da nur Gatterlaufzeiten hat. Mit denselben Methoden kann man aber auch die Abfragen vereinfachen. Wenn man das nun nicht ausrechnen will, kann man das natürlich mit einer Tabelle umsetzen.
-
@john-0 sagte in IF-Abfrage:
Mit denselben Methoden kann man aber auch die Abfragen vereinfachen.
Und ich erinnere mich noch düster an die KV Diagramme
-
Ihr habt alle recht. Ich möchte mir einen kleinen Computer selber basteln, und dafür brauche ich das.
Das XOR war schon ganz schön anstrengend (https://de.wikipedia.org/wiki/Exklusiv-Oder-Gatter#Synthese).
PS. Den KV-Würfel verstehe ich nicht.
-
@Quiche-Lorraine sagte in IF-Abfrage:
Und ich erinnere mich noch düster an die KV Diagramme
Darauf bin ich vorhin als ich das alte Uni-Skript aus dem Regal holte auch gestoßen. Die disjunktive Normalform war mir noch im Gedächtnis, die KV-Diagramme nicht mehr.
-
@john-0 sagte in IF-Abfrage:
Danke, dass du die Notation verwendet hast, ich finde die immer extrem gut lesbar. Die ist irgendwie bei den Elektrotechnikern beliebt, aber die Mathematiker wollten damals nix davon wissen und haben auf dieses unsägliche /-Hütchenspiel bestanden, bei dem man Flimmern vor den Augen bekommt (ich zumindest).... aber ich kann das schon verstehen - man muss schliesslich mit beidem klar kommen. Ich war aber bei viele Zeilen langen Ausdrücken nie so schnell und hab so wenig Fehler gemacht, wie mit dieser Digitaltechnik-Notation
Edit: Dein Audruck da oben könnte auch so aussehen, wenn ich mich nicht vertippt hab (grusel!):
-
@Finnegan sagte in IF-Abfrage:
Dein Audruck da oben könnte auch so aussehen, wenn ich mich nicht vertippt hab (grusel!)
Eii, das Forum/der Browser scheint damit Darstellungsprobleme zu haben.^^
Edit: Man darf aber auch Klammern setzen, falls es sonst zu unübersichtlich wird ...
-
@tech-house sagte in IF-Abfrage:
@Finnegan sagte in IF-Abfrage:
Dein Audruck da oben könnte auch so aussehen, wenn ich mich nicht vertippt hab (grusel!)
Eii, das Forum/der Browser scheint damit Darstellungsprobleme zu haben.^^
Ja, ich habs grad noch auf 2 Zeilen aufgesplittet, der Latex-Renderer scheint einfach abzuschneiden, wenns zu lang wird (zumindest mit $latex$). Bei mir siehts jetzt richtig aus ... und es ist schon ein Zeichen für eine bessere Notation, wenn man es auch ohne die eigentlich nicht notwendigen Klammern gut lesen kann.
-
@Finnegan sagte in IF-Abfrage:
Bei mir siehts jetzt richtig aus
Bei mir auch. Noch mal BTT.: Ich muss sagen, dass mir die E-Techniker-Schreibweise (also das hoch- bzw. übergestellte - für Not und das seltsame + für Oder und das implizite Und, welches gar nicht mehr auftaucht) "tendenziell eher etwas weniger gut" gefällt.
-
@tech-house sagte in IF-Abfrage:
@Finnegan sagte in IF-Abfrage:
Bei mir siehts jetzt richtig aus
Bei mir auch. Noch mal BTT.: Ich muss sagen, dass mir die E-Techniker-Schreibweise (also das hoch- bzw. übergestellte - für Not und das seltsame + für Oder und das implizite Und, welches gar nicht mehr auftaucht) "tendenziell eher etwas weniger gut" gefällt.
Man macht sich halt u.a. auch die algebraische Analogie zwischen / und zunutze. Letzteres lernt man bereits sehr früh und hat es dementsprechend gut drauf, so dass mans meist intuitiv richtig macht. Gerade auch was Umstellen und Vereinfachen von Ausdrücken angeht.
-
@Finnegan sagte in IF-Abfrage:
Ja, ich habs grad noch auf 2 Zeilen aufgesplittet, der Latex-Renderer scheint einfach abzuschneiden, wenns zu lang wird (zumindest mit $latex$). Bei mir siehts jetzt richtig aus ... und es ist schon ein Zeichen für eine bessere Notation, wenn man es auch ohne die eigentlich nicht notwendigen Klammern gut lesen kann.
Was mich stört, dass der LaTeX Renderer nicht die übliche align bzw. alignat Umgebung bietet. Mit dieser lassen sich längere Formeln besser umbrechen.
-
@tech-house sagte in IF-Abfrage:
Ich dachte, das logische XOR wäre in C++
!=
, und das^
gäbe es gar nicht...Es gibt in C++ kein logisches XOR.
^
ist "bitwise" XOR.
Und!=
ist "ungleich".So lange man aber ausschliesslich mit
bool
Inputs arbeitet, und das Ergebnis dann alsbool
interpretiert, bekommt man mit beiden das selbe raus.
-
Aber das ist für
bool
s dann doch äquivalent zu einem logischen XOR! Demnach gibt es dies.
-
@tech-house sagte in IF-Abfrage:
Aber das ist für
bool
s dann doch äquivalent zu einem logischen XOR! Demnach gibt es dies.Ne,!=
ist nur die halbe Miete. Für XOR muss auch noch einer der beiden Ausdrücke wahr sein ... also sowas wie(A != B) && (A || B)
Edit: Äh, Moment mal. Stimmt, die können ja nur ungleich sein, wenn einer wahr und einer falsch ist. Ich glaube du hast doch recht, oder verpeil ich hier auch was?
!=
ist tatsächlich wie ein logisches XOR ... hatt ich auch nicht auf dem Schirm, klingt erstmal so falschSo mal ganz doof:
A | B | != ---------- 0 | 0 | 0 0 | 1 | 1 1 | 0 | 1 1 | 1 | 0
A | B | XOR ------------ 0 | 0 | 0 0 | 1 | 1 1 | 0 | 1 1 | 1 | 0
... aber es stimmt schon, man nennt es eben nicht "logisches XOR" und es macht auch etwas mehr, da es eben im Vergleich zu
||
und&&
nicht nurbool
-Inputs akzeptiert, bzw. die Operanden nicht implizit nachbool
konvertiert. Aber das ist im Prinzip das, was @hustbaer ja auch geschrieben hat.
-
Nein, mir ging es um Folgendes:
^
ist das arithmetische XOR in C/C++ ...
^
ist fürbool
s aber nicht definiert => Kompilierfehler.
Deshalb nimmt man fürbool
types den!=
-Operator.
Der!=
-Operator verhält sich fürbool
types logisch äquivalent zum logischen XOR.
Deshalb wäre es für mich naheliegend, beibool
types und dem!=
-Operator auch vom logischen XOR zu sprechen.
Dass der!=
-Operator für andere types auch "noch mehr kann" als eine reine XOR-Verknüpfung, und er so gesehen sozusagen überladen wäre, spielt in erster Linie doch keine Rolle.
Auf unterster Ebene liegt für zweibool
-Werte ein XOR vor (siehe Analyse von @wob) ...
Daher würde ich "!=
ist "ungleich"" und "ein logisches XOR gibt es in C/C++ nicht" widersprechen, da ungenau ... eher würde ich sagen,!=
ist "vielgestaltig" in C/C++.Selbstverständlich ist das etwas Korinthenkacka, aber ich bin an der Stelle lieber etwas genauer als "zu ungenau falsch". Das ist doch hoffentlich verständlich?
-
@tech-house
^
ist arithmetische XOR, soweit richtig.
Es ist auch richtig dass es fürbool
nicht definiert ist. Genaugenommen ist es für keinen Typ definiert der formal kleiner alsint
ist. Genau so wie+
,-
etc.Das bedeutet aber nicht dass du einen Kompilierfehler bekommst. Es bedeutet dass "integral promotions" auf beiden Seiten gemacht werden. Konkret wird dabei jeder Typ der formal kleiner als
int
ist zuint
oderunsigned int
konvertiert. Siehe https://en.cppreference.com/w/cpp/language/implicit_conversion#Integral_promotionD.h. bei folgendem Code:
bool b1; bool b2; auto x = b1 ^ b2;
Macht der Compiler das daraus:
bool b1; bool b2; int x = static_cast<int>(b1) ^ static_cast<int>(b2);
Siehe https://cppinsights.io
Deshalb wäre es für mich naheliegend, bei
bool
types und dem!=
-Operator auch vom logischen XOR zu sprechen.Die Operatoren die in C++ als logische Operatoren bezeichnet werden konvertieren ihre Argumente zwingend nach
bool
. Daher ergibt1 && 2
als Ergebnistrue
- wohingegen1 & 2
als Ergebnis0
hat -- was dann zufalse
wird wenn man es nachbool
konvertiert.Und
!=
verhält sich hier wie&
, nicht wie&&
. Denn1 != 2
isttrue
, wohingegen1 LOGICAL_XOR 2
als Ergebnisfalse
haben müsste. Daher wäre es sehr irreführend es als "logisches XOR" zu bezeichnen.Daher würde ich "!= ist "ungleich"" und "ein logisches XOR gibt es in C/C++ nicht" widersprechen, da ungenau ... eher würde ich sagen, != ist "vielgestaltig" in C/C++.
Selbstverständlich ist das etwas Korinthenkacka, aber ich bin an der Stelle lieber etwas genauer als "zu ungenau falsch". Das ist doch hoffentlich verständlich?Nein. Du bist zu ungenau. Der eingebaute
!=
Operator ist immer "ungleich" und der eingebaute^
Operator ist immer bitweise XOR. Und logisch XOR gibt es nicht. Das ist genau.
-
Aber
2
ist doch gar kein validerbool
-Wert.bool b1 = 2;
werde ich wahrscheinlich nicht schreiben können.Somit fehlt die Argumentationsgrundlage für deine Argumentation, imho.
-
@tech-house sagte in IF-Abfrage:
Aber
2
ist doch gar kein validerbool
-Wert.bool b1 = 2;
werde ich wahrscheinlich nicht schreiben können.Probier es doch mal selbst aus, statt herumzuraten. Denn das geht. Dabei werden zahlen != 0 zu true evaluiert (ist das der richtige begriff hier?).
Beispielcode:bool b1 = 2; bool b2 = 0; bool b3 = -1; std::cout<<b1<<':'<<b2<<':'<<b3<<'\n';
Ausgabe:
1:0:1