AGB  ·  Datenschutz  ·  Impressum  







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

listen generisches array

Ein Thema von loki · begonnen am 20. Apr 2005 · letzter Beitrag vom 20. Apr 2005
Antwort Antwort
loki

Registriert seit: 7. Dez 2004
5 Beiträge
 
#1

listen generisches array

  Alt 20. Apr 2005, 09:42
hallo.
ich brauche mal kurz hilfe.
ich hab folgende aufgabe:

Beim Aufräumen haben Sie im Keller ein Puzzle gefunden. Die 9 Teile sollen so zu einem Quadrat zusammengefügt werden, dass an jeder Kante ein durchgehender Pfeil und ggf. eine komplette geometrische Figur entsteht. Nach etwas Probieren haben Sie immerhin 8 Teile passend zusammengefƒugt, nur das Teil mit der Nummer 7 passt nicht in die verbleibende Ecke.
Schreiben Sie ein Programm, dass alle möglichen Lösungen des Puzzles ausgibt (geben Sie für die 3 Reihen jeweils an, welche Teile dort verwendet und ob diese um 90, 180 oder 270 Grad gedreht wurden).

Bild dazu:
http://home.arcor.de/mario.neichel/puzzel.JPG

Wie gehe ich das am besten an?
Kann ich eine generische Liste auf ein Array tun? (hab sowas im Raum schweben hören) und wenn ja wie?

würde mich auf antwort freuen.
loki

[edit=sakura] - hilfe - aus dem Titel geworfen, die brauchen wir alle Mfg, sakura[/edit]
  Mit Zitat antworten Zitat
Benutzerbild von Binärbaum
Binärbaum

Registriert seit: 19. Jan 2005
Ort: Elstra
764 Beiträge
 
Delphi 7 Enterprise
 
#2

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 09:53
Nur als Stichwort: man könnte Backtracking verwenden, umdas Problem zu lösen.

MfG
Binärbaum
//Edit: ach ja: willkommen in der DP!
There are exactly 10 kinds of people: those who understand binary, and those who don't.
---
"Software reift beim Kunden. Bei Hardware ist es anders: Hardware fault beim Kunden." - Rainer G. Spallek
  Mit Zitat antworten Zitat
Waldteufel
(Gast)

n/a Beiträge
 
#3

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 09:58
Hi.

Ich empfehle ein 2-dimensionales Array für das aufbewahren der Puzzleteile. Sowas in dieser Richtung:

Delphi-Quellcode:
type
  TPuzzle = array[1..3, 1..3] of TPuzzleteil; // 9 Puzzleteile
  TPuzzleteil = array[1..4] of TPfeil; // 4 Richtungen
  TPfeil = (pfPfeilSpitze, pfPfeilRest, pfQuadratSpitze, {...});
  Mit Zitat antworten Zitat
Benutzerbild von leddl
leddl

Registriert seit: 13. Okt 2003
Ort: Künzelsau
1.613 Beiträge
 
Delphi 2006 Professional
 
#4

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 10:25
Nur müßtest du da jetzt noch für jedes Puzzleteil die Nr und die aktuelle Drehung einbauen. Schließlich muß das später mit angegeben werden
Axel Sefranek
A programmer started to cuss, cause getting to sleep was a fuss.
As he lay there in bed, looping round in his head
was: while(!asleep()) ++sheep;
  Mit Zitat antworten Zitat
loki

Registriert seit: 7. Dez 2004
5 Beiträge
 
#5

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 14:29
danke für so vielen schnelle antworten.
an backtracking habe ich auch schon gedacht, doch das hat im worst case exponentielle Laufzeit. das ist verdammt viel. und wenn ich mir das so ansehe, kann das verdammt lange dauern. hm .. viell bleibt mir auch nix anderes übrig?

ne mögliche darstellung habe ich auch schon. aber aber immer für vorschläge offen.

Delphi-Quellcode:
package Puzzle is
  
    type Orientation_Type is ( North, East, South, West ); -- 0, 90, 180, 270
    type Match_Neighbour_Type is ( Yes, No, Not_Applicable );
  
    type Element_Type is
    record
       Orientation : Orientation_Type;
       Arrow_Direction : Oreintation_Type;
       Match_Left_Neighbour : Match_Neighbour_Type;
       Match_Right_Neighbour : Match_Neighbour_Type;
       Match_Upper_Neighbour : Match_Neighbour_Type;
       Match_Lower_Neighbour : Match_Neighbour_Type;
    end record;
  
    type Board_Type is array ( 1..3, 1..3 ) of Element_Type;
   
 end Puzzle;
freu mich auf weitere antworten

loki
  Mit Zitat antworten Zitat
Waldteufel
(Gast)

n/a Beiträge
 
#6

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 14:34
Hi.

Zitat von loki:
Delphi-Quellcode:
package Puzzle is
  
    type Orientation_Type is ( North, East, South, West ); -- 0, 90, 180, 270
    type Match_Neighbour_Type is ( Yes, No, Not_Applicable );
  
    type Element_Type is
    record
       Orientation : Orientation_Type;
       Arrow_Direction : Oreintation_Type;
       Match_Left_Neighbour : Match_Neighbour_Type;
       Match_Right_Neighbour : Match_Neighbour_Type;
       Match_Upper_Neighbour : Match_Neighbour_Type;
       Match_Lower_Neighbour : Match_Neighbour_Type;
    end record;
  
    type Board_Type is array ( 1..3, 1..3 ) of Element_Type;
   
 end Puzzle;
Ein Feld kann mehrere Pfeile haben und die 4 Match_..._Neighbour kann man zusammenfassen, also

Delphi-Quellcode:
Arrow_Directions : array (1..4) of Orientation_Type;
Match_Neighbour : array (1..4) of Match_Neighbour_Type;
  Mit Zitat antworten Zitat
Benutzerbild von Binärbaum
Binärbaum

Registriert seit: 19. Jan 2005
Ort: Elstra
764 Beiträge
 
Delphi 7 Enterprise
 
#7

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 15:15
Zitat von Waldteufel:
Delphi-Quellcode:
Arrow_Directions : array (1..4) of Orientation_Type;
Match_Neighbour : array (1..4) of Match_Neighbour_Type;
Bei Arrays verwendet man aber immer eckige Klammern [ und ]

MfG
Binärbaum
There are exactly 10 kinds of people: those who understand binary, and those who don't.
---
"Software reift beim Kunden. Bei Hardware ist es anders: Hardware fault beim Kunden." - Rainer G. Spallek
  Mit Zitat antworten Zitat
Waldteufel
(Gast)

n/a Beiträge
 
#8

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 15:22
Hi.

Zitat von Binärbaum:
Bei Arrays verwendet man aber immer eckige Klammern [ und ]
Das war doch gar nicht Pascal...

[edit] Das war ADA... [/edit]
  Mit Zitat antworten Zitat
loki

Registriert seit: 7. Dez 2004
5 Beiträge
 
#9

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 16:12
@waldteufel
danke für die idee, doch ich fürchte um die übersichtlichkeit. und wenn die aufgabe kontrolliert wird und der typ lange braucht um durch zu blicken, wird der mir punkte abziehen

@binärbaum
das mit den klammern ist ok, pseudo code reicht mir auch.
und in ada sind es auch normale klammern, und in pascal weis ich das gar nicht mehr, hab schon ewig nicht mehr pascaliert *g* und wozu gibt es fehlermeldungen?


@all
wie würdet ihr den grund algorith. angehen?

loki
  Mit Zitat antworten Zitat
Waldteufel
(Gast)

n/a Beiträge
 
#10

Re: - hilfe - listen generisches array

  Alt 20. Apr 2005, 16:22
Hi.

Zitat von loki:
@all: wie würdet ihr den grund algorith. angehen?
Verschachtelte For-Schleifen

Delphi-Quellcode:
for i := 1 to 3 do
  for j := 1 to 3 do
    for k := 1 to 4 do
    begin
      Teile[i, j].Rotieren(k);
      Teile[i, j].Ausgeben;
    end;
oder Rekursion

Delphi-Quellcode:
procedure MachDas(i : integer);
begin
  if (i <> 9) then
  begin
    Rotieren;
    MachDas(i + 1);
    Rotieren;
    MachDas(i + 1);
    Rotieren;
    MachDas(i + 1);
    Rotieren;
    MachDas(i + 1);
  end;
end;
  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 18:05 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