Retrieving an Element of an Array: Difference between revisions

From Rosetta Code
Content added Content deleted
mNo edit summary
Line 1: Line 1:
{{task}}
[http://some-omeelse.110mb.com/data/mp-plug.htm mp3 plug play] [http://some-omeelse.110mb.com/data/sl-.htm sl 55 amg] [http://funk-mastah-ion.110mb.com/data/singola-cerca.htm singola cerca uomo] [http://yeeden.110mb.com/data/e-non/ e non liberarci dal male] [http://trene-von-anty.110mb.com/description/memory-stick.htm memory stick duo (1 gb)] [http://sister-sunshine.110mb.com/html/yamaha-cdrhd/ yamaha cdrhd1300] [http://olikka.110mb.com/library/dive-tv.htm dive tv nude] [http://dialed.110mb.com/small/polti-lecoaspira/ polti lecoaspira 700] [http://forever-your.110mb.com/data/radio-edit.htm radio edit] [http://trene-von-anty.110mb.com/description/musica-michel.htm musica michel sardou] [http://unremig.110mb.com/grande-cartina/ grande cartina africa] [http://lazythoughts.110mb.com/lib/darlington/ darlington] [http://stitchesnglue.110mb.com/comunista-italiano.htm comunista italiano] [http://book-wench.110mb.com/text/piantina-di/ piantina di milano] [http://blue-olusha.110mb.com/library/lo-zingaro/ lo zingaro felice] [http://yeeden.110mb.com/data/tutti-i/ tutti i cellulari nokia bluetooth] [http://stitchesnglue.110mb.com/phyto.htm phyto] [http://olikka.110mb.com/library/video-murder.htm video murder nick berg] [http://lazythoughts.110mb.com/lib/lan-adapter/ lan adapter] [http://mouse-zae.110mb.com/plextor-masterizzatori.htm plextor masterizzatori dvd dual layer] [http://gekijuls.110mb.com/kurram/ kurram] [http://dialed.110mb.com/small/ivy-queen/ ivy queen videos] [http://dialed.110mb.com/small/anycom-bluetooth/ anycom bluetooth] [http://sister-sunshine.110mb.com/html/foto-cellulari/ foto cellulari] [http://yeeden.110mb.com/data/tps/ tps 16 11 2004] [http://sister-sunshine.110mb.com/html/palermo-singole/ palermo singole] [http://sneezingpops.110mb.com/soul-of/ soul of chogokin] [http://nationavce.110mb.com/view/obsesion-von.htm obsesion von aventura] [http://trouble166.110mb.com/lultimo-ribelle.htm lultimo ribelle] [http://mouse-zae.110mb.com/lcpower-silent.htm lcpower silent giant lc6550g v2 0] [http://trouble166.110mb.com/t-rio.htm t rio choopeta mamae eu quero] [http://stitchesnglue.110mb.com/toyota-corolla.htm toyota corolla 13] [http://trene-von-anty.110mb.com/description/copertine-walt.htm copertine walt disney] [http://olikka.110mb.com/library/la-morte.htm la morte dietro il cancello] [http://mouse-zae.110mb.com/www-screen.htm www screen saver gratis it] [http://slavkamolot.110mb.com/library/biciclette-ciclismo/ biciclette ciclismo] [http://yeeden.110mb.com/data/la-peccatrice/ la peccatrice adolescente] [http://stitchesnglue.110mb.com/gi-da.htm gi da] [http://slavkamolot.110mb.com/library/dempster-thomas/ dempster thomas] [http://slavkamolot.110mb.com/library/la-terra/ la terra dimenticata dal tempo] [http://lazythoughts.110mb.com/lib/mitac-mio/ mitac mio 168 limited ed] [http://funk-mastah-ion.110mb.com/data/navigatori-per.htm navigatori per moto] [http://unremig.110mb.com/offerte-di/ offerte di lavoro come cameriera] [http://some-omeelse.110mb.com/data/hp-proliant.htm hp proliant ml150 g2] [http://forever-your.110mb.com/data/capriccio-spagnolo.htm capriccio spagnolo] [http://unremig.110mb.com/motorini-dell/ motorini dell anno] [http://sister-sunshine.110mb.com/html/aeroporto-bari/ aeroporto bari] [http://mouse-zae.110mb.com/scheda-grafica.htm scheda grafica 256] [http://some-omeelse.110mb.com/data/gli-ultimi.htm gli ultimi cinque minuti] [http://book-wench.110mb.com/text/agenzia-matrimoniale/ agenzia matrimoniale treviso] [http://gekijuls.110mb.com/mutuo-tasso/ mutuo tasso agevolato] [http://forever-your.110mb.com/data/inovix-imp.htm inovix imp65] [http://forever-your.110mb.com/data/scheda-video.htm scheda video ati radeon 9550 256 tv out] [http://dialed.110mb.com/small/donne-mature/ donne mature it] [http://dialed.110mb.com/small/residuale/ residuale] [http://lazythoughts.110mb.com/lib/come-dancing/ come dancing] [http://olikka.110mb.com/library/voli-da.htm voli da verona a roma] [http://forever-your.110mb.com/data/dvd-portatile.htm dvd portatile daewoo] [http://gekijuls.110mb.com/ci-sara/ ci sara enrico ruggeri] [http://yeeden.110mb.com/data/mesa-que/ mesa que mas aplauda za za za] [http://unremig.110mb.com/albo-odontotecnici/ albo odontotecnici] [http://funk-mastah-ion.110mb.com/data/jvc-gzmce.htm jvc gzmc500e] [http://trouble166.110mb.com/decapitazione-libanese.htm decapitazione libanese] [http://sister-sunshine.110mb.com/html/sigla-wav/ sigla wav cartoni animati] [http://stitchesnglue.110mb.com/tubo-luminoso.htm tubo luminoso] [http://sneezingpops.110mb.com/cover-con/ cover con canzoni m2o] [http://dialed.110mb.com/small/leitz-xyron/ leitz xyron] [http://funk-mastah-ion.110mb.com/data/scopata.htm scopata] [http://trouble166.110mb.com/english-aljazeera.htm english aljazeera net] [http://yeeden.110mb.com/data/humiliation/ humiliation] [http://trene-von-anty.110mb.com/description/converti-da.htm converti da divx a dvd] [http://sneezingpops.110mb.com/bmw-nuove/ bmw nuove] [http://yeeden.110mb.com/data/izvorna-kalesija/ izvorna kalesija] [http://blue-olusha.110mb.com/library/discorso-mussolini/ discorso mussolini] [http://blue-olusha.110mb.com/library/das-ist/ das ist die perfekte welle das ist der pe] [http://mouse-zae.110mb.com/hamlet-.htm hamlet zelig syncbox usb] [http://book-wench.110mb.com/text/supa-dupa/ supa dupa fly 666] [http://dialed.110mb.com/small/eminem-e/ eminem e] [http://sister-sunshine.110mb.com/html/ultime-notizie/ ultime notizie tra carolina e tommaso] [http://blue-olusha.110mb.com/library/la-diferencia/ la diferencia] [http://stitchesnglue.110mb.com/palmari-satellitari.htm palmari satellitari] [http://nationavce.110mb.com/view/ypsilon.htm ypsilon 04] [http://book-wench.110mb.com/text/guerra-marina/ guerra marina] [http://funk-mastah-ion.110mb.com/data/tubi-di.htm tubi di rame d 4] [http://sneezingpops.110mb.com/scarica-conzoni/ scarica conzoni] [http://unremig.110mb.com/retelilliput/ retelilliput] [http://nationavce.110mb.com/view/cameron-mitchell.htm cameron mitchell] [http://dialed.110mb.com/small/decapitazioni-terroristi/ decapitazioni terroristi] [http://unremig.110mb.com/areasex/ areasex] [http://some-omeelse.110mb.com/data/crok.htm crok 2] [http://trene-von-anty.110mb.com/description/il-mondo.htm il mondo che non c e di simone] [http://gekijuls.110mb.com/scheda-madre/ scheda madre pci express 775] [http://book-wench.110mb.com/text/palmari-palmone/ palmari palmone] [http://funk-mastah-ion.110mb.com/data/nba-live.htm nba live 2004] [http://unremig.110mb.com/esibizioniste-calze/ esibizioniste calze] [http://forever-your.110mb.com/data/il-pennello.htm il pennello di lacca] [http://forever-your.110mb.com/data/albergo-bassano.htm albergo bassano del grappa] [http://gekijuls.110mb.com/mitsubishi-pajero/ mitsubishi pajero] [http://trene-von-anty.110mb.com/description/usato-motorino.htm usato motorino] [http://unremig.110mb.com/ministero-degli/ ministero degli interni] [http://mouse-zae.110mb.com/spiaggia-scambisti.htm spiaggia scambisti] [http://sneezingpops.110mb.com/diverti-pc/ diverti pc] [http://trene-von-anty.110mb.com/description/actionman.htm actionman] [http://lazythoughts.110mb.com/lib/canon/ canon 90] [http://gekijuls.110mb.com/milano-biciclette/ milano biciclette] [http://some-omeelse.110mb.com/data/magia-nuda.htm magia nuda] [http://book-wench.110mb.com/text/donne-anziane/ donne anziane over50] [http://dialed.110mb.com/small/driver-lexmark/ driver lexmark z34] [http://mouse-zae.110mb.com/oakley-half.htm oakley half wire xl] [http://mouse-zae.110mb.com/late-schow.htm late schow] [http://sneezingpops.110mb.com/dragoesta/ dragoesta] [http://sister-sunshine.110mb.com/html/spot-pubblicita/ spot pubblicita freddy] [http://gekijuls.110mb.com/istituto-alberghiero/ istituto alberghiero pescara] [http://some-omeelse.110mb.com/data/licei-statali.htm licei statali serali provincia milano] [http://forever-your.110mb.com/data/verbatim-sd.htm verbatim sd] [http://sneezingpops.110mb.com/cd-check/ cd check] [http://stitchesnglue.110mb.com/pompini-famosi.htm pompini famosi] [http://lazythoughts.110mb.com/lib/numeri-telefono/ numeri telefono campania] [http://sneezingpops.110mb.com/annuncio-personali/ annuncio personali foto avellino] [http://unremig.110mb.com/picture-mate/ picture mate epson] [http://dialed.110mb.com/small/www-looney/ www looney tunes com] [http://olikka.110mb.com/library/people-get.htm people get ready 99] [http://trene-von-anty.110mb.com/description/conversione-pdf.htm conversione pdf word] [http://book-wench.110mb.com/text/la-sapienza/ la sapienza] [http://ultra-creator.110mb.com/articles/bidone-aspirapolvere.htm bidone aspirapolvere con funzione] [http://stitchesnglue.110mb.com/kodak-.htm kodak fotocamere digitali easyshare] [http://gekijuls.110mb.com/nokia-/ nokia 6600 memory] [http://funk-mastah-ion.110mb.com/data/blof-countin.htm blof countin crows] [http://slavkamolot.110mb.com/library/mercati-cereali/ mercati cereali bologna] [http://stitchesnglue.110mb.com/uccisione-americano.htm uccisione americano in iraq] [http://stitchesnglue.110mb.com/tm.htm tm 2702] [http://slavkamolot.110mb.com/library/download-cento/ download cento colpi di spazzola] [http://trene-von-anty.110mb.com/description/samba-pati.htm samba pati] [http://ultra-creator.110mb.com/articles/mahjongg.htm mahjongg] [http://blue-olusha.110mb.com/library/la-demo/ la demo multiplayer di pariah] [http://trouble166.110mb.com/villa-flaminia.htm villa flaminia] [http://forever-your.110mb.com/data/immagini-autopsie.htm immagini autopsie] [http://yeeden.110mb.com/data/trans-super/ trans super truccate] [http://book-wench.110mb.com/text/traduzione-fuck/ traduzione fuck you] [http://sister-sunshine.110mb.com/html/lemarie/ lemarie] [http://sister-sunshine.110mb.com/html/logitechdriving-force/ logitechdriving force] [http://forever-your.110mb.com/data/le-porte.htm le porte girevoli] [http://nationavce.110mb.com/view/ultime-su.htm ultime su keanu reeves] [http://mouse-zae.110mb.com/fujifilm-finepix.htm fujifilm finepix e500] [http://slavkamolot.110mb.com/library/la-canzone/ la canzone di pippo gol] [http://sneezingpops.110mb.com/castiglione-della/ castiglione della pescaia] [http://olikka.110mb.com/library/invasione-usa.htm invasione usa] [http://slavkamolot.110mb.com/library/piumino-da/ piumino da uomo aspesi] [http://olikka.110mb.com/library/electronica.htm electronica] [http://funk-mastah-ion.110mb.com/data/baggi.htm baggi] [http://sneezingpops.110mb.com/corneliani/ corneliani] [http://sister-sunshine.110mb.com/html/la-campana/ la campana fa din don] [http://lazythoughts.110mb.com/lib/cofano/ cofano] [http://trouble166.110mb.com/office-.htm office 2003 pro edu] [http://trene-von-anty.110mb.com/description/scherfig-hans.htm scherfig hans] [http://dialed.110mb.com/small/donna-matura/ donna matura in roma] [http://lazythoughts.110mb.com/lib/klaus-kinski/ klaus kinski] [http://trouble166.110mb.com/la-vendetta.htm la vendetta dei moschettieri] [http://sister-sunshine.110mb.com/html/radeon-/ radeon 9800 pro 256] [http://gekijuls.110mb.com/ddr-/ ddr333 256 memoria ram] [http://book-wench.110mb.com/text/foto-di/ foto di elvis presley] [http://book-wench.110mb.com/text/i-pod/ i pod socks] [http://lazythoughts.110mb.com/lib/videoregistratore-dvd/ videoregistratore dvd videoregistratori] [http://forever-your.110mb.com/data/sportback-ambiente.htm sportback ambiente] [http://nationavce.110mb.com/view/irvine-welsh.htm irvine welsh] [http://dialed.110mb.com/small/il-generale/ il generale dei desperados] [http://trene-von-anty.110mb.com/description/www-googles.htm www googles com co] [http://yeeden.110mb.com/data/pioneer-cdj/ pioneer cdj200] [http://yeeden.110mb.com/data/the-cars/ the cars drive] [http://gekijuls.110mb.com/www-vaiper/ www vaiper it] [http://slavkamolot.110mb.com/library/iety-vari/ iety vari] [http://slavkamolot.110mb.com/library/slim-masterizzatori/ slim masterizzatori cd] [http://sister-sunshine.110mb.com/html/ethernet-wifi/ ethernet wifi] [http://stitchesnglue.110mb.com/psc.htm psc 2175] [http://mouse-zae.110mb.com/museo-del.htm museo del calzado] [http://mouse-zae.110mb.com/bobby-solo.htm bobby solo la siesta midi] [http://lazythoughts.110mb.com/lib/canna-fumaria/ canna fumaria] [http://lazythoughts.110mb.com/lib/calling-you/ calling you traduzione testo] [http://ultra-creator.110mb.com/articles/giochi-greci.htm giochi greci] [http://stitchesnglue.110mb.com/dingelstedt-franz.htm dingelstedt franz von] [http://some-omeelse.110mb.com/data/leghe-metalliche.htm leghe metalliche] [http://nationavce.110mb.com/view/decoder-digitali.htm decoder digitali sat] [http://dialed.110mb.com/small/babysitter-cercasi/ babysitter cercasi a padova] [http://slavkamolot.110mb.com/library/video-maroon/ video maroon 5] [http://mouse-zae.110mb.com/beverly-hills.htm beverly hills cops] [http://nationavce.110mb.com/view/haeju.htm haeju] [http://slavkamolot.110mb.com/library/vendita-ingrosso/ vendita ingrosso] [http://book-wench.110mb.com/text/austin-ristorante/ austin ristorante] [http://lazythoughts.110mb.com/lib/sms-gratis/ sms gratis iscrizione] [http://olikka.110mb.com/library/luomo-che.htm luomo che vinse la morte] [http://stitchesnglue.110mb.com/hotel-miranda.htm hotel miranda di rimini] [http://blue-olusha.110mb.com/library/assicurazione-massa/ assicurazione massa] [http://gekijuls.110mb.com/renault-scenic/ renault scenic 2003] [http://trene-von-anty.110mb.com/description/garmin-gps.htm garmin gps map 60] [http://olikka.110mb.com/library/nikon-af.htm nikon af 3570mm f 3 34 5] [http://unremig.110mb.com/joselito-in/ joselito in america] [http://sister-sunshine.110mb.com/html/ti/ ti 850] [http://lazythoughts.110mb.com/lib/upgrade-office/ upgrade office] [http://sister-sunshine.110mb.com/html/jab/ jab] [http://gekijuls.110mb.com/hub-usb/ hub usb 10 porte] {{task}}


In this task, the goal is to retrieve an element of an [[array]].
In this task, the goal is to retrieve an element of an [[array]].
Line 15: Line 15:
mov esi, array_offset
mov esi, array_offset
mov ebx, 2
mov ebx, 2
mov eax, [esi ebx*4]
mov eax, [esi+ebx*4]


==[[ActionScript]]==
==[[ActionScript]]==
Line 54: Line 54:
}
}
==[[C plus plus|C ]]==
==[[C plus plus|C++]]==
[[Category:C plus plus|C ]]
[[Category:C plus plus|C++]]


template<typename T>
template<typename T>
Line 139: Line 139:
Forth does not have special syntax for array access. Address arithmetic is used to access contiguous memory.
Forth does not have special syntax for array access. Address arithmetic is used to access contiguous memory.
create array 1 , 2 , 3 , 4 ,
create array 1 , 2 , 3 , 4 ,
array 2 cells @ . \ 3
array 2 cells + @ . \ 3


==[[IDL]]==
==[[IDL]]==

Revision as of 22:40, 25 August 2007

Task
Retrieving an Element of an Array
You are encouraged to solve this task according to the task description, using any language you may know.

In this task, the goal is to retrieve an element of an array.

4D

  ` first element
$elem:=$array{1}

X86 assembly

Assembler: nasm

mov esi, array_offset
mov ebx, 2
mov eax, [esi+ebx*4]

ActionScript

var arr:Array = new Array(1,2,3);
var myVar:Number = arr[1];
// the value of myVar is: 2

Ada

Array indexed by an enumerated type. Ada enumerated types are discrete non-numeric types.

type Days is (Mon, Tue, Wed, Thu, Fri, Sat, Sun);
type Daily_Counts is array(Days) of Natural;
This_week : Daily_Counts := (200, 212, 175 220, 201, 120, 0);
Monday_Sales : Natural;
Monday_Sales := This_Week(Mon); 

Monday_Sales is assigned 200

AppleScript

on getArrayValue(array, location)
    -- very important -- The list index starts at 1 not 0
    return item location in array
end getArrayValue

C

 int array_index(int array[], int index) {
   return array[index];
 }

C#

 int getArrayValue( int values[], int index ) {
   return values[index];
 }
 

C++

 template<typename T>
 T array_index(T array[], size_t index) {
   return array[index];
 }

ColdFusion

<cfset arr = ArrayNew(1)>
<cfset arr[1] = "one">
<cfset arr[2] = "2">
<cfset arr[3] = 3>
<cfset var = arr[1]>

The value of var is "one"

ColdFusion Arrays are NOT zero-based, their index begins at 1

Common Lisp

  (defun array-value (array index)
    (aref array index))

Delphi/Object Pascal/Turbo Pascal/Standard Pascal

Array's in all the flavors of pascal can be of any valid base type, or user defined type ( which are all made up of base types ) and are multi-dimensional. With Delphi dynamic arrays were defined but had been used in pascal since its inseption.

A Static array defintion:

foo : array[1..10] of integer; { The base index is ONE }

The base index can be freely chosen:

foo: array[7 .. 16] of integer; { The base index is 7 }

Indeed, the "1 .. 10" resp. "7 .. 16" are actually types: they are integer subrange types. Arrays can also be indexed by enumeration types or enumeration subrange types:

type
 rainbowcolor = (red, orange, yellow, green, blue, violet);
var
 foo: array[rainbowcolor] of integer;
 bar: array[yellow .. blue] of integer;
 i: integer
begin
 i := foo[red]; { allowed indices are red, orange, yellow, green, blue, violet }
 i := bar[green]; { allowed indices are yellow, green, blue }
end;

A Dynamic Array type in Delphi:

foo : array of integer ; // The base index is ZERO

An "old school" dynamic array in the various flavors of pascal

foo : array[0..0] of integer;  // The base index is ZERO

A dynamic array in Extended Pascal:

type
 intarray(n: integer) = array[1 .. n] of integer; { base index 1 }
var
 foo: ^intarray;
begin
 new(foo, 10); { foo now has index 1 to 10 }
 i := foo[2];
 dispose(foo); { get rid of the array }
end;

In the case of the static array, the compiler generates the code to allocate the required memory to hold 10 integers.

In the Delphi style ---dynamic--- array you must set its length:

SetLength(foo,10);  // this array will no hold 10 integers

In the "old school" style of dynamic arrays, you created a point to the zero length declaration and then allocated memory to it with GetMem

pFoo : ^Foo ;
Foo  : array[0..0] of integer ;

All arrays are accessed the same way regardless of declaration method.

i : integer ;

i := foo[n] ;

where n is the array index who's base is either 1 or 0 depending on how it was declared.

Erlang

Erlang lists are 1-based which means that the index must be within the bounds (1 .. length(List)):

Value = lists:nth(Index, List).

Forth

Forth does not have special syntax for array access. Address arithmetic is used to access contiguous memory.

create array 1 , 2 , 3 , 4 ,
array 2 cells + @ .    \ 3

IDL

 ; this is allowed:
 result = arr(5) 
 ; but this is preferred:
 result = arr[5]

The form with square brackets is preferred as it unambiguously constitutes array access, while the version with round ones can conflict with a function call if there are both a function and an array with the same name arr.

Java

public Object getArrayElem(Object[] array, int pos) {
    return array[pos];
}

JavaScript

var element = array[index];

mIRC

Interpeter: mIRC Script Editor

Library: mArray Snippet

 alias readmyarray { echo -a $array_read(MyArray, 2, 3) }

Perl

Interpreter: Perl 5.8.8

$elem = $array[0];

PHP

$array = array('php', 'has', 'arrays');
// First element 
$elem  = $array[0];

Pop11

lvars ar = {1 two 'three'};
lvars elem;
;;; Access second element and assign to variable elem
ar(2) -> elem;

This example uses the simplest possible array (a vector). Pop11 has more general arrays, but in all cases access follows the same pattern, and look the same as procedure (function) call.

Python

Interpreter: Python 2.5

The item is an element in a list at a given index

 item = aList[index]

or

To use a list like a stack be it FIFO/LIFO

 aList.pop()  # Pop last item in a list
 aList.pop(0) # Pop first item in a list

Note: When using the pop() method, the element is removed from the list.

Ruby

 ary = ['Ruby','rules','big','time']
 #the first element
 element = ary[0]
 #or
 element = ary.first
 # => element = 'Ruby'
 #the last element
 element = ary[-1]
 #or
 element = ary.last
 # => element = 'time'
 #retrieving different values at once
 elements = ary.values_at(0,2,3)
 # => elements = ['Ruby','big','time']
 #select the first element of length 3
 element = ary.find{|el|el.length==3}
 # => element = "big"

Smalltalk

  "Retrieve second element of an array"
  index := 2
  element := anArray at: index

Tcl

All arrays in Tcl are associative. If "key" is the variable that holds the key of the element to be retrieved, then

 set result $array($key)

Toka

This retrieves the value 20 from the second item in the array:

 3 cells is-array table
 ( Populate the array )
 10 0 table put-element
 20 1 table put-element 
 30 2 table put-element
 
 table 1 get-element