Schrift
[thread]6655[/thread]

ein Array als neue Elemente in ein anderes einfüge: und dabei ein anderes Element löschen



<< >> 7 Einträge, 1 Seite
mordur
 2005-01-24 12:00
#51186 #51186
User since
2003-09-25
182 Artikel
BenutzerIn
[Homepage] [default_avatar]
moins,

ich habe zwei Arrays:
Code: (dl )
1
2
my @array1=(1,2,3,4,5);
my @array2=(a,b,c,d,e);

Jetzt soll an einer bestimmten Stelle des ersten Arrays das zweite eingefügt werden und zwar so, das alle Elemente des zweiten Elements NICHT ein Element des ersten darstellen, sondern jedes einzelne Element des zweiten Arrays auch ein neues Element des ersten Arrays wird. Dabei steht ein Element des ersten Arrays als Schlüssel das gesamte zweite Array:
z.B. 3 verweist auf array2
Das bedeutet das das ganze array2 an Stelle des Elements "3" des ersten eingefügt wird und Element "3" aus dem ersten Array entfernt werden muss.
Am Ende muss das Array1 so aussehen:
Code: (dl )
@array1=(1,2,a,b,c,d,e,4,5);

Die Sortierung der beiden Arrays darf nicht verändert werden!
Relais
 2005-01-24 12:09
#51187 #51187
User since
2003-08-06
2246 Artikel
ModeratorIn
[Homepage] [default_avatar]
Code: (dl )
1
2
3
4
my @array1=(1,2,3,4,5);
my @array2=(a,b,c,d,e);
splice @array1, 2, 1, @array2;
print join( ",", @array1 ), "\n";


perldoc -f splice
Erst denken, dann posten --
27. Deutscher Perl- u. Raku -Workshop (Termin wird noch gesucht) 2025 in München.

Winter is Coming
mordur
 2005-01-24 13:20
#51188 #51188
User since
2003-09-25
182 Artikel
BenutzerIn
[Homepage] [default_avatar]
zählt der Offset die Elemente oder den Index? d.h. beginnt er bei 1 oder bei 0 ?
Crian
 2005-01-24 13:24
#51189 #51189
User since
2003-08-04
5870 Artikel
ModeratorIn
[Homepage]
user image
Code: (dl )
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
> perldoc -f splice
   splice ARRAY,OFFSET,LENGTH,LIST
   splice ARRAY,OFFSET,LENGTH
   splice ARRAY,OFFSET
   splice ARRAY
           Removes the elements designated by OFFSET and LENGTH from an
           array, and replaces them with the elements of LIST, if any. In
           list context, returns the elements removed from the array. In
           scalar context, returns the last element removed, or "undef" if
           no elements are removed. The array grows or shrinks as
           necessary. If OFFSET is negative then it starts that far from
           the end of the array. If LENGTH is omitted, removes everything
           from OFFSET onward. If LENGTH is negative, removes the elements
           from OFFSET onward except for -LENGTH elements at the end of the
           array. If both OFFSET and LENGTH are omitted, removes
           everything. If OFFSET is past the end of the array, perl issues
           a warning, and splices at the end of the array.

           The following equivalences hold (assuming "$[ == 0"):

               push(@a,$x,$y)      splice(@a,@a,0,$x,$y)
               pop(@a)             splice(@a,-1)
               shift(@a)           splice(@a,0,1)
               unshift(@a,$x,$y)   splice(@a,0,0,$x,$y)
               $a[$x] = $y         splice(@a,$x,1,$y)

           Example, assuming array lengths are passed before arrays:

               sub aeq {   # compare two list values
                   my(@a) = splice(@_,0,shift);
                   my(@b) = splice(@_,0,shift);
                   return 0 unless @a == @b;       # same len?
                   while (@a) {
                       return 0 if pop(@a) ne pop(@b);
                   }
                   return 1;
               }
               if (&aeq($len,@foo[1..$len],0+@bar,@bar)) { ... }


Offset ist der Index des ersten Elements, bei dem die Ersetzung beginnt. Er beginnt natürlich bei 0, es geht doch um Arrays.\n\n

<!--EDIT|Crian|1106566195-->
s--Pevna-;s.([a-z]).chr((ord($1)-84)%26+97).gee; s^([A-Z])^chr((ord($1)-52)%26+65)^gee;print;

use strict; use warnings; Link zu meiner Perlseite
mordur
 2005-01-24 14:29
#51190 #51190
User since
2003-09-25
182 Artikel
BenutzerIn
[Homepage] [default_avatar]
hm...
Wie würde sich das Konstrukt denn in er foreach-Schleife verhalten?
Code: (dl )
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
my @array1=(1,2,3,4,5);
my @array2=(a,b,c,d,e);

foreach my $x(0..$#array1)
{
my $switch;
$switch='Y' if $x==2;
if( $switch eq "Y")
{
splice @array1, $x, 1, @array2;
# ist array1 jetzt hier bereits 'verlängert' ?
# d.h. der nächste Wert von $array[$x] ist 'a' ?
# oder wird nur eine Kopie erstellt, die dann nach
# abarbeiten der Schleife gültig wird?
}

}
\n\n

<!--EDIT|mordur|1106569991-->
Relais
 2005-01-24 14:43
#51191 #51191
User since
2003-08-06
2246 Artikel
ModeratorIn
[Homepage] [default_avatar]
@mordur: bist Du zum selber testen denn zu faul?

Das wäre falsche Faulheit, die ist al solche tatsächlich schädlich für Dich, weil Du damit nicht lernst.

Wenn Du Code schon hinschreiben kannst, kannst Du ihn doch auch testen, oder?
Erst denken, dann posten --
27. Deutscher Perl- u. Raku -Workshop (Termin wird noch gesucht) 2025 in München.

Winter is Coming
Crian
 2005-01-24 15:16
#51192 #51192
User since
2003-08-04
5870 Artikel
ModeratorIn
[Homepage]
user image
Und wenn Du testest wirst Du feststellen, dass es schlau wäre das ganze Rückwärts zu machen.

Testen kannst Du gut mit

Code: (dl )
print "'", join(', ', @array), "'\n";


oder mit

Code: (dl )
print Dumper \@array;



(und use Data::Dumper; vorweg)
s--Pevna-;s.([a-z]).chr((ord($1)-84)%26+97).gee; s^([A-Z])^chr((ord($1)-52)%26+65)^gee;print;

use strict; use warnings; Link zu meiner Perlseite
<< >> 7 Einträge, 1 Seite



View all threads created 2005-01-24 12:00.