AGB  ·  Datenschutz  ·  Impressum  







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

überprüfen ob eine schnittmenge vorhanden ist

Ein Thema von napstar · begonnen am 1. Dez 2013 · letzter Beitrag vom 1. Dez 2013
Antwort Antwort
Benutzerbild von napstar
napstar

Registriert seit: 22. Mär 2007
Ort: München
133 Beiträge
 
Delphi 2007 Architect
 
#1

überprüfen ob eine schnittmenge vorhanden ist

  Alt 1. Dez 2013, 14:22
hallo ich studiere informatik im 1. semester..
wir haben eine aufgabe bekommen die ich bis heute abend fertig haben mus

leider komme ich nicht mehr weiter.. ich muss das ganze zwar in java realisieren.. aber mir geht es nicht um den code.. sondern eher wie ich es realisieren soll..

also ich habe eine klasse point und eine klasse rectange
nun muss ich ne methode schreiben die true zurückliefert, wenn 2 rechtecke eine schnittmenge haben..

kann mir jemand einen ansatz verraten?..

danke schonmal im vorraus..
  Mit Zitat antworten Zitat
Der schöne Günther
Online

Registriert seit: 6. Mär 2013
6.110 Beiträge
 
Delphi 10 Seattle Enterprise
 
#2

AW: überprüfen ob eine schnittmenge vorhanden ist

  Alt 1. Dez 2013, 16:02
Das ist doch nicht kompliziert:

Wäre ich faul, würde ich einfach java.awt.geom.* einbinden und die Klassen Point2D und Rectangle2D = class(Arc2D) verwenden

Aber wenn man selbst nachdenken soll: Wenn du die Schnittmenge nicht einmal bestimmen sollst, sondern nur feststellen, ob überhaupt eine vorhanden ist:

Ich hätte spontan einfach nur geschaut, ob auf der X-Achse die Punkte B1 oder B4 oder beide zwischen A1 und A4 liegen. Wenn ja, das gleiche nochmal für die Y-Achse.
Miniaturansicht angehängter Grafiken
geometrie-des-wahnsinns-phnglui-mglwnafh-cthulhu-rlyeh-wgahnagl-fhtagn.png  
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: überprüfen ob eine schnittmenge vorhanden ist

  Alt 1. Dez 2013, 16:15
Code:
P1 = Max( A.TopLeft, B.TopLeft )
P2 = Min( A.BottomRight, B.BottomRight )
dabei ist
Code:
Max( P1, P2 ) : Point
R.x = Max( P1.x, P2.x )
R.y = Max( P1.y, P2.y )
Das Minimum analog dazu

Jetzt muss nur noch die Bedingung erfüllt sein, dass
Code:
P1.x <= P2.x und P1.y <= P2.y
Eine Sonderbedingung ist, wenn P1=P2, dann ist die Schnittmenge ein Punkt

PS

Wichtig ist noch, die Bereiche vor der Analyse zu normalisieren (d.h. TopLeft liegt wirklich auch oben links)
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo ( 1. Dez 2013 um 16:33 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Aphton
Aphton

Registriert seit: 31. Mai 2009
1.198 Beiträge
 
Turbo Delphi für Win32
 
#4

AW: überprüfen ob eine schnittmenge vorhanden ist

  Alt 1. Dez 2013, 21:08
Eine andere, einfachere Variante ist dieser hier:

EsGibtKeineSchnittmenge = NOT(EsGibtEineSchnittmenge)

Für EsGibtKeineSchnittmenge gibt es genau 4 Fälle:
(Beziehe mich auf die Graphik bei der Antwort #2)
A1.X > B4.X OR
A4.X < B1.X OR
A1.Y > B2.Y OR
A2.Y < B1.Y

Da du die Schnittmenge (Ein Rechteck) an sich nicht berechnen musst, reichen diese 4 Bedingungen!
das Erkennen beginnt, wenn der Erkennende vom zu Erkennenden Abstand nimmt
MfG
  Mit Zitat antworten Zitat
Der schöne Günther
Online

Registriert seit: 6. Mär 2013
6.110 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: überprüfen ob eine schnittmenge vorhanden ist

  Alt 1. Dez 2013, 21:38
Das ist alles viel zu eindeutig, wir brauchen polarisierende Glaubensfragen.

Wäre die Software nicht gleich viel besser wartbar, wenn wir stattdessen eine Methode zur Bestimmung der Schnittmenge mit einem anderen Rechteck implementieren? Wenn es keine Schnittmenge in der Ebene gibt, wird eben nil oder ein spezielle Null-Instanz zurückgegeben. Klar verbraten wir unnütz Leistung wenn wir in 95% der Fälle wirklich nur wissen wollen, ob es überhaupt eine gibt. Aber ich meine ja nur
  Mit Zitat antworten Zitat
Benutzerbild von Aphton
Aphton

Registriert seit: 31. Mai 2009
1.198 Beiträge
 
Turbo Delphi für Win32
 
#6

AW: überprüfen ob eine schnittmenge vorhanden ist

  Alt 1. Dez 2013, 22:21
Ja klar; gilt aber nur für ordentliche Software.

Nicht für elementare Probleme, mit denen sich Studenten beschäftigen sollen, damit sie zuerst einmal ihre analytischen Skills verbessern. Klar könnte man das so machen, ist aber ned zwingendermaßen Ziel der Übung!

Designtechnische Sachen kommen später im Studium!

Meine Meinung
das Erkennen beginnt, wenn der Erkennende vom zu Erkennenden Abstand nimmt
MfG
  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 09:22 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