AGB  ·  Datenschutz  ·  Impressum  







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

Zwei Arrays vergleichen

Ein Thema von Luckie · begonnen am 4. Feb 2003 · letzter Beitrag vom 5. Feb 2003
Antwort Antwort
Benutzerbild von Luckie
Luckie

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

Zwei Arrays vergleichen

  Alt 4. Feb 2003, 06:50
Hallo.
Jetzt wird es etwas komplizierter. Ich habe zwei Arrays A und B. OK, bis hierher war es noch einfach.
A={1,2,3}
B={2,3,4,5}

So Aufagbe:
Ich brauche jetzt in Array C alle Elemente die in A enthalten sind aber nicht in B. (Wäre hier 1)
Und alle Elemente in Array D die in B drin sind aber nicht in A. (Wäre hier 4 und 5)

Es kann aber auch sein, dass Array A mehr Elemente enthält, wie Array B.

Das zu programmieren dürfte kein Problem sein. Ich brauche nur eine Idee / Algoritmus. Aber jedesmal, wenn ich mitten drin bin im Überlegen bekomme ich ein Knoten ins Hirn und verliere den Überblick und weiß dann nicht mehr, wo ich war.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
CB2206

Registriert seit: 4. Feb 2003
Ort: Kaarst
13 Beiträge
 
Delphi 7 Enterprise
 
#2
  Alt 4. Feb 2003, 07:02
Code:
function in_array(bla: integer; arr: array of integer): Boolean
begin
  result := false;
  for a := 0 to Length(arr) do
    if (arr[a] = bla) then begin
      result := True;
      exit;
    end;
end;


{...}
SetLength(array3, 0);
for a := 0 to length(array1) - 1 do
  if not in_array(array1[a], array2) then begin
   SetLength(array3, Length(array3) + 1);
   array3[Length(array3) - 1] := array1[a];
  end;
end;

SetLength(array4, 0);
for a := 0 to length(array2) - 1 do
  if not in_array(array2[a], array1) then begin
   SetLength(array4, Length(array4) + 1);
   array4[Length(array4) - 1] := array2[a];
  end;
end;
{...}
Gruß
CB
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#3
  Alt 4. Feb 2003, 07:51
Die Idee mit dem in_array war der Springendepunkt. Habe es hinbekommen. Eine Lösung kann ich aber nicht posten, würde nichts bringen. Nur so viel man muß drei Fälle unterscheide:
A ist genauso groß wie B, A ist kleiner wie B, A ist größer wie B.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
CB2206

Registriert seit: 4. Feb 2003
Ort: Kaarst
13 Beiträge
 
Delphi 7 Enterprise
 
#4
  Alt 4. Feb 2003, 07:55
der Lösungsansatz steht ja oben...das sollte reichen...
Gruß
CB
  Mit Zitat antworten Zitat
Benutzerbild von nailor
nailor

Registriert seit: 12. Dez 2002
Ort: Karlsruhe
1.989 Beiträge
 
#5
  Alt 4. Feb 2003, 19:08
alternativ kannst du dir mal Sets anschaun...
Michael N.
http://nailor.devzero.de/code/sharpmath/testing/ --- Tests, Feedback, Anregungen, ... aller Art sehr willkommen!
::: don't try so hard - it'll happen for a reason :::
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#6
  Alt 4. Feb 2003, 19:10
Kann man Sets dynamisch erstellen?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
jbg

Registriert seit: 12. Jun 2002
3.483 Beiträge
 
Delphi 10.1 Berlin Professional
 
#7
  Alt 4. Feb 2003, 20:00
Es kommt darauf an, was du mit dynamisch meinst.

Delphi-Quellcode:
var aSet, bSet, cSet: set of Byte;
begin
  aSet := aSet + [10];
  Include(aSet, 20);

  bSet := [10, 20, 30];
  cSet := aSet * bSet; { = [10, 20] }
end;
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#8
  Alt 4. Feb 2003, 21:17
Es müßten Strings sein und zur Laufzeit kenn ich weder Anzahl der Elemente in einem Set noch wie sie heißen. Das meinte ich mit dynamisch.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Christian Seehase
(Co-Admin)

Registriert seit: 29. Mai 2002
Ort: Hamburg
11.107 Beiträge
 
Delphi 11 Alexandria
 
#9
  Alt 5. Feb 2003, 00:54
Moin Luckie,

simpel, ungetestet, aber sollte gehen:

Delphi-Quellcode:
for i := low(A) to high(A) do
begin
  fFound := false;
  for j := low(B) to high(B) do
  begin
    if A[i] = B[j] then
    begin
      fFound := true;
      break;
    end;
  end;
  if not fFound then
  begin
    // Zu C hinzufügen
  end;
end;
Für die andere Richtung dann analog.

BTW: Und ich hab' so die Ahnung, als hätte ich Dir dieses Problem auch noch eingebrockt
Tschüss Chris
Die drei Feinde des Programmierers: Sonne, Frischluft und dieses unerträgliche Gebrüll der Vögel.
Der Klügere gibt solange nach bis er der Dumme ist
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#10
  Alt 5. Feb 2003, 01:18
Wenn meine Mail nicht untergegangen ist, dann kennst du ja meine Lösung. Nicht so elegant, wie deine aber sie scheint zu funktionieren.
Michael
Ein Teil meines Codes würde euch verunsichern.
  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 07:42 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