AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Alle "logischen Möglichkeiten" auflisten

Ein Thema von flomei · begonnen am 18. Apr 2005 · letzter Beitrag vom 18. Apr 2005
Antwort Antwort
Benutzerbild von flomei
flomei

Registriert seit: 17. Jan 2003
Ort: Schieder-Schwalenberg
2.094 Beiträge
 
Delphi 2005 Personal
 
#1

Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 15:51
Hallo!
Der Titel is vielleicht nen bisschen ungeschickt gewählt, worum es mir geht ist folgendes:
Wir behandeln in Informatik jetzt das Thema Logik (AND, NAND, OR, etc.pp.) und dürfen immer so tolle "Wertetabellen" zeichnen.
Beispiel:
Code:
A, B
Möglichkeiten:
w f
w w
f w
f f

A, B, C
Möglichkeiten:
w w w
w w f
w f f
f f f
f f w
f w w
f w f
w f w

...
Ja, und so weiter... Ich denke ihr habt das Prinzip verstanden.
Informatiker sind natürlich faul und deswegen würden sie sich gerne ein Programm schreiben das ihnen diese Folgen in eine Textdatei schreibt. Und zwar für x Variablen...
Leider weiss ich nicht so recht wie ich anfangen soll.
"Alles richtig" und "alles falsch" is noch einfach aber wie geht man dazwischen am Besten vor?

Wer irgendwelche Ideen, Lösungsvorschläge oder was weiss ich was hat, immer her damit...

Danke!

MFG Florian
Florian Meier
... ist raus.
Vielen Dank für die Zeit mit euch!
http://www.flomei.de -- http://www.md5hash.de
  Mit Zitat antworten Zitat
Dax
(Gast)

n/a Beiträge
 
#2

Re: Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 15:55
Nimm doch, was dir ein Prozessor bietet: Zahlen.

Deine Wahr/Falsch-Tabellen mit den Variablen A, B, C, D, ... Z kannst du auf 32Bit-Zahlen übertragen:

Bit 1, Bit 2, Bit 3, Bit 4 .... Bit 26, ... Bit 32

Wenn du alle Werte haben willst, zähle von 0 solange hoch, bis alle Variablen wahr (also 1) sind. Dann musst du nur noch mit AND die entsprechenden Bits herausfiltern und als w (für 1) oder f (für 0) in die Datei schreiben.

Edit: Alternativ kannst du mit einem array of Boolean arbeiten, dann ist es aber viel schwerer, die entsprechenden Werte mit geringem Aufwand zu bekommen.
  Mit Zitat antworten Zitat
Chris1986

Registriert seit: 17. Jul 2003
Ort: Aachen
350 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 15:59
hi flomei,
eigentlich kannst du doch binär hochzählen. Es gibt immer 2^n Möglichkeiten.
Die erste Möglichkeit ist FF... und die 2^n te WW . . .
Bei 2 Variablen also folgendes (geordnetes) Schema:
Delphi-Quellcode:
FF
WF
FW
WW
Das müsste sich doch mit 2 Schleifen relativ einfach realisieren lassen.

MfG
Christian
Es gibt nur 10 Typen von Menschen auf der Welt:
Die, die Binärcode verstehen und die, die es nicht tun . . .
  Mit Zitat antworten Zitat
Benutzerbild von glkgereon
glkgereon

Registriert seit: 16. Mär 2004
2.287 Beiträge
 
#4

Re: Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 16:03
wie wäre es damit?(getestet)

Delphi-Quellcode:
function GetKombi(ValCount: Integer): TStringList;
var Temp: TStringList;
  procedure kombiRec(index, max: Integer; vals: String);
  var i:Integer;
  begin
    for i:=1 to 2 do
      if index<max then
        kombirec(index+1,max,vals+IntToStr(i))
      else Temp.Add(vals+IntToStr(i));
  end;
begin
  Temp:=TStringList.Create;
  KombiRec(1,ValCount,'');
  Result:=TStringList.Create;
  Result.Clear;
  Result.AddStrings(Temp);
  Temp.Free;
end;
und nun ausgabe mit w/f statt 1/2:
Delphi-Quellcode:
function GetKombi(ValCount: Integer): TStringList;
var Buf: TMemoBuf;
  procedure kombiRec(index, max: Integer; vals: String);
  var i:Integer;
  begin
    for i:=1 to 2 do
      if index<max then
        kombirec(index+1,max,vals+IntToStr(i))
      else Result.Add(vals+IntToStr(i));
  end;
begin
  Result:=TStringList.Create;
  Result.Clear;

  KombiRec(1,ValCount,'');

  Buf:=TMemoBuf.Create;
  Buf.Append(Result.Text);
  Buf.ReplaceAll('1','w');
  Buf.ReplaceAll('2','f');

  Result.Clear;
  Result.Add(Buf.Text);
end;
»Unlösbare Probleme sind in der Regel schwierig...«
  Mit Zitat antworten Zitat
Benutzerbild von flomei
flomei

Registriert seit: 17. Jan 2003
Ort: Schieder-Schwalenberg
2.094 Beiträge
 
Delphi 2005 Personal
 
#5

Re: Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 16:10
Das von Gereon scheint zu gehen, da jag ich jetzt noch nen paar StringReplace drüber und speicher das in ner Textdatei oder so.
Tausend Dank!

MFG Florian

edit: OK, hat er schon gemacht. werd mir das mal noch genauer angucken...
Florian Meier
... ist raus.
Vielen Dank für die Zeit mit euch!
http://www.flomei.de -- http://www.md5hash.de
  Mit Zitat antworten Zitat
Benutzerbild von glkgereon
glkgereon

Registriert seit: 16. Mär 2004
2.287 Beiträge
 
#6

Re: Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 16:13
also TMemoBuf is in der Unit RpMemo und das einzige objekt was ich kenne was ReplaceAll kennt...
»Unlösbare Probleme sind in der Regel schwierig...«
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#7

Re: Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 16:15
Delphi-Referenz durchsuchenStringReplace.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von flomei
flomei

Registriert seit: 17. Jan 2003
Ort: Schieder-Schwalenberg
2.094 Beiträge
 
Delphi 2005 Personal
 
#8

Re: Alle "logischen Möglichkeiten" auflisten

  Alt 18. Apr 2005, 16:18
Ja, hab grad trotzdem nen paar Sprachen durcheinander geworfen...

MFG Florian

Falls irgendwer mal das Gleiche suchen sollte und seine Hausaufgaben schnell erledigt haben will, dann kann er sich das Programm (klein und hässlich) ja mal aussem Anhang runterladen...

[edit] NEIN, ich will nicht über neue Antworten benachrichtigt werden. Ich lebe in diesem Forum, deshalb bekomm ich das auch so mit... [/edit]
Angehängte Dateien
Dateityp: exe true-false_133.exe (460,0 KB, 6x aufgerufen)
Florian Meier
... ist raus.
Vielen Dank für die Zeit mit euch!
http://www.flomei.de -- http://www.md5hash.de
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:00 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz