![]() |
4 Variablen sollen = 1302 sein.
Hey ihr Delphi- Kenner,
ich habe das Problem, dass ich 4 Variablen habe, die zusammen 1302 sollen:
Delphi-Quellcode:
Wenn ich das Programm starten möchte sagt Delphi :
w * x - y + z = 1302;
Der linken Seite kann nichts zugewiesen werden Weiß einer von euch, wie ich das Problem beheben kann? Euer Dave |
Re: 4 Variablen sollen = 1302 sein.
Ich habe nicht die geringste Ahnung, was du da tun willst. Soll das eine Zuweisung sein oder willst du die Variablen auf irgendetwas überprüfen?
|
Re: 4 Variablen sollen = 1302 sein.
w, x, y und z sollen zusammen 1302 sein...
z.B. 1 * 1302 - 2 + 2 = 1302 |
Re: 4 Variablen sollen = 1302 sein.
Sieht sehr nach einem Konstrukt mit vier For-Schleifen aus, die solange ausprobieren, bis was gefunden wurde.
|
Re: 4 Variablen sollen = 1302 sein.
Genau das meine ich :)
Wie aber kann ich das machen? |
Re: 4 Variablen sollen = 1302 sein.
Zitat:
Code:
Das ist aber nicht korrekt, da es eigentlich unendlich viele Lösungen gibt (es sei denn, Du schränkst den Wertebereich ein, so wie ich es hier getan habe).
var
w, x, y, z: Integer [...] for w := Low(Integer) to High(Integer) do begin for x := Low(Integer) to High(Integer) do begin for y := Low(Integer) to High(Integer) do begin for z := Low(Integer) to High(Integer) do begin if w * x - y + z = 1302 then begin ShowMessageFmt("%0:d * %1:d - %2:d + %3:d", [w, x, y, z]); end; end; end; end; end; // Edit: Natürlich kann man das noch optimieren, ist halt ein Quick-and-Dirty-Ansatz, der Deinen Rechner und Dich einige Zeit lang beschäftigen dürfte. |
Re: 4 Variablen sollen = 1302 sein.
Hallo,
kann es sein, das "DAS" eine Primfaktoren-Analyse werden soll ? |
Re: 4 Variablen sollen = 1302 sein.
also erstmal geht soeine Zuweisung garnicht, da es mehrere Lösungen gibt und woher soll Delphi wissen wie was da zugewiesen werden soll.
schon alleine für Folgendes gibt es 13533 Lösungen
Delphi-Quellcode:
und das obwohl ich die Wertebereiche eingeschrenkt und doppelte Lösungen ignoriert hab.
var
x, y, z: Integer; begin for x := -1000 to 1000 do for y := x to 1000 do for z := -1000000 to 1000000 do if x * y + z = 1302 then Memo1.Lines.Add(Format('%d * %d + %d = 1302', [x, y, z])); Memo1.Lines.Add(Format('%d Lösungen', [Memo1.Lines.Count])); end; x und y kann hier ja getauscht werden, was dann sozusagen fast doppelt soviele Lösungen Ergäbe. jo, und je mehr Variablen und um so größer der wertebereich .... um so mehr wird es du kannst ja mal schauen wie lange dieses hier braucht, um alles auszutesten und wie viel Lösungen es dann gibt :angel2:
Delphi-Quellcode:
wobei es hierfür schon eine sehr einfache vereinfachung gibt ... siehe erster Code ... ohne z2 prüfen und dann z nochmals in z-z2 zwelegen
procedure TForm1.Button1Click(Sender: TObject);
var x, y, z, z2, q: Integer; begin q := 0; for x := -1000 to 1000 do for y := -1000 to 1000 do for z := -1000000 to 1000000 do for z2 := -1000000 to 1000000 do if x * y + z - z2 = 1302 then begin if (q < 1000) or (q and $ff = 0) then Memo1.Lines.Add(Format('%d * %d + %d - %d = 1302', [x, y, z, z2])); Inc(q); end; Memo1.Lines.Add(Format('%d Lösungen', [q])); end; |
Re: 4 Variablen sollen = 1302 sein.
// Edit: Ah, da war wohl einer schneller als ich :) (siehe oben)
trotzdem sende ich meine Antwort nochmal ;) Zitat:
Muss ich mal machen ... :) Aber diesmal wird es keine Primfaktorenanalyse... ;) So, jetzt nochmal 'ne Rückmeldung:
Delphi-Quellcode:
Das habe ich jetzt geschrieben, man kann das Programm auch starten, wenn man allerdings auf den Button1 klickt passiert nichts und dann kann man garnichts mehr machen, das komplette Programm bleibt stehen und man kann es nicht mehr übers "X" schließen
procedure TForm1.Button1Click(Sender: TObject);
var w, x, y, z : Integer; begin for w := Low(1) to High(9) do begin for x := Low(1) to High(9999) do begin for y := Low(1) to High(9999) do begin for z := Low(1) to High(9999) do begin if w * x - y + z = 1302 then begin Label1.Caption := IntToStr(w); Label2.Caption := IntToStr(x); Label3.Caption := IntToStr(y); Label4.Caption := IntToStr(z); end; end; end; end; end; end; end. :gruebel: mhhhhh.... komisch... aber vielleicht kann mir ja nochmal jemand helfen ;) Wäre cool, Euer Dave |
Re: 4 Variablen sollen = 1302 sein.
Low(1) ist wahrscheinlich -2^31 und High(9) ist wahrscheinlich 2^31-1. Das heißt, deine Berechnung braucht seeeehr lange. ;)
|
Re: 4 Variablen sollen = 1302 sein.
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo,
ich glaube nicht, dass sich Dein Programm "aufhängt" - der Auslastungsanzeige nach arbeitet es, die Frage ist nur, wie lange ?? ...hab nach 2 Minuten abgebrochen |
Re: 4 Variablen sollen = 1302 sein.
Warum generierst du nicht einfach drei Zufallszahlen und nimmst für die vierte die Differenz zu deinem Zielwert?
|
Re: 4 Variablen sollen = 1302 sein.
Ähem! 2^128 Schleifendurchläufe, wie ich bereits bemerkt habe. Selbst auf einem absolut utopischen Superrechner dauert das 1348785383850751774 Jahre. ;)
EDIT: Die ganze Aufgabenstellung ist absolut unsinnig. Es ist möglich, in konstanter Zeit ein solches Tupel zu finden und es ist absolut unmöglich, alle zu finden, weil es unendlich viele gibt. |
Re: 4 Variablen sollen = 1302 sein.
Ist doch völlig trivial, wenn keine Bedingungen gestellt werden (und sollten von den Schleifen auch gefunden werden). Lösunge von w * x - y + z = 1302 dutch hinsehen:
w x y z 0 x 0 1302 0 x 1 1303 .... w 0 0 1302 w 0 1 1303 1 1302 y -y und so weiter und sofort. Gammatester |
Re: 4 Variablen sollen = 1302 sein.
Zitat:
Sobald die 4503599627370496 Durchläufe fertig sind... Denn High(9) ist 127, denn das ist innerhalb des Datentyps Byte, High(9999) ist 32767, denn das ist im Datentyp Word. 32768 * 32768 * 32768 * 128 = 4503599627370496 Bei schätzungsweise einer halben Milliarde Durchläufe pro Sekunde mit einem modernen PC würde das etwa 4 Tage dauern... Ohne Low und High mit i := 1 to 9999 usw. würde es immer noch 5 Stunden oder so dauern. |
Re: 4 Variablen sollen = 1302 sein.
Also mal zur kurzen Darstellung (was auch schon meine Vorredner erkannt haben) hast du ein 3fach unbestimmtes Gleichungssystem. Dies bedeutet für mich eigentlich nur eins, dass du unendlich viele Lösungen (allein im Bereich der Ganzen- oder Integerzahlen) hast. Nimmst du ein Reales Zahlensystem sollte sich der Raum an möglichen Lösungen um die Potenz Unendlich erweitern.
Dein Vorteil, soweit du die Suche der Möglichen Kombination nicht durch weitere Verknüpfungen einschränkst(z.B. x = 2w, ...), ist die limitierte Verarbeitung deines Rechners mit Zahlen. Also ergibt sich eine berechenbare Anzahl (auch wenn diese ziemlich groß) an Lösungen, was allerdings, wie ich jaenicke entnehme eine "kurze" Weile dauern sollte. Fazit für dich sollte sein, dass du dir über die Randbedingungen (Mathematische Räume in denen sich deine Zahlen bewegen sollen, Abhängigkeiten einzelner Variablen von anderen und so weiter)klarer wirst. Allerdings ist auch hier etwas Vorsicht zu bewahren, schnell rutscht man mal in den Bereich der komplexen Zahlen und erweitert damit die Anzahl an Lösungen warscheinlich um eine Dimension unendlicher Lösungen. Ps.: ich weiß mathematisch gesehen sind hier leichte Ungenauigkeiten enthalten, was allerdings aufgrund der Verständlichkeit für Laien zu verschmerzen sein sollte. Möchte das hier nicht in eine theoretisch mathematische Diskusion ausarten lassen, in der über Theorien wie "Ist Unendlich hoch irgendwas nicht immer noch Unendlich" oder oder oder. Ich denke der Punkt, die Aufgabenstellung vieleicht nochmal zu überdenken ist damit verständlich rüber gekommen. BAMatze |
Re: 4 Variablen sollen = 1302 sein.
Ich hab da auch ne Lösung :stupid:
Delphi-Quellcode:
Und das sogar in konstanter Zeit (= O(1) ) wenn nicht gar schneller ;)
function Get_w(): Integer;
begin Result := 20; end; function Get_x(): Integer; begin Result := 70; end; function Get_y(): Integer; begin Result := 100; end; function Get_z(): Integer; begin Result := 2; end; // Aufruf: procedure evaluate; begin Result := Get_w * Get_x - Get_y + Get_z; // ergibt 1302 end; |
Re: 4 Variablen sollen = 1302 sein.
Ich kenne ne Möglichkeit, die schneller als deine wäre ;)
(deine beinhaltete zu viele Jumps & Push/Pops) :P MfG |
Re: 4 Variablen sollen = 1302 sein.
Zitat:
Deshalb ist eben wirklich die Frage was das ganze für einen Sinn hat. :stupid: |
Re: 4 Variablen sollen = 1302 sein.
Das finde ich wirklich 'ne gute Idee, ich werde das jetzt mal ausprobieren.
Vielen Dank für die reichlichen Antworten und Ideen zum Thema. Euer Dave |
Re: 4 Variablen sollen = 1302 sein.
@jfheins:
Wie kann ich denn dann die Zahlen ausgeben, die errechnet wurden? Viele Grüße Dave |
Re: 4 Variablen sollen = 1302 sein.
Zitat:
w = 20 x = 70 y = 100 z = 2 Möchte dir nur mal die Tragweite der Möglichen Lösungen darstellen. Variable 1.Mögliche Kombination 2. 3. 4. 5. 6. .... w 1 1 1 1 1 1 x 1 1 1 1 1 1 y 1 2 3 -1 -2 -3 z 1302 1303 1304 1300 1299 1298 Alle diese Werte LÖSEN dein Problem und es geht wie man sieht für w unendlich viele Werte, x unendlich viele, y unendlich viele und z ergänzt das ganze einfach nur. Grob gesagt, wie ich schon mal in einem vorherigen Beitrag geschrieben hatte sind das mindestens unendlich hoch 3 (grobe Schätzung) verschiedene Kombinatonen. Wie gesagt, die eingeschränkte Technik (die maximale Größe für Integerzahlen) hilft dir dort eingeschränkt. Um dir das nochmal (auch wenn es andere schonmal geschrieben haben) klar zu machen, bedeutet das, und ich gehe davon aus du hast ein auf 32 Bit basierendes System bedeutet es (wenn mich meine Kenntnisse verlassen) du hast für w 2^32 verschiedene Werte, für x 2^32 und für y 2^32 und wie gesagt z ergänst das ganze nur. 2^32 bedeutet dabei 4294967296 verschiedene Zahlen, ist schonmal "etwas" kleiner als Unendlich. das bedeutet für dich du hast mindestens 4294967296^3 verschiedene mögliche Kombinationen. Was in etwa 7,9*10^28 sind und dabei hab ich noch abgerundet!! Bist du dir WIRKLICH sicher, dass du diese Aufgabe so weiterhin bestehen lassen möchtest? Und zur Veranschaulichung nur nochmal: Du hast 79000000000000000000000000000 verscheidene Möglichkeiten ( hoffe ich hab mich bei den Nullen nicht vertan, sollten 27 sein, die 9 ist ja die 28.Stelle) MfG BAMatze |
Re: 4 Variablen sollen = 1302 sein.
Willst du wirklich ausrechnen, welche Werte die 4 Variablen annehmen können? Oder hast du die Variablen davor definiert und willst dann überprüfen ob sie die Zahl 1302 ergeben?
Das wäre nämlich sehr, sehr einfach:
Delphi-Quellcode:
Edit: Ich verweise auf einen Thread von dir:
if (w * x - y + z) = 1302 then
//hier Befehl wenn die Zahlen 1302 ergeben ![]() |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:30 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz