Retrieving an Element of an Array: Difference between revisions

From Rosetta Code
Content added Content deleted
mNo edit summary
(revert spam)
Line 1: Line 1:
{{task}}
[http://listmishyk.ifrance.com/kenia-tour/index.html kenia tour] [http://thecrownless.ifrance.com/il-secondo/index.html il secondo] [http://chasingspaces.ifrance.com/hanquoc/index.html hanquoc] [http://chasingspaces.ifrance.com/gabriela-toscano/index.html gabriela toscano] [http://pupsik1993.ifrance.com/left-outsida-alone.html left outsida alone] [http://cuivenarius.ifrance.com/hcitarra.html hcitarra] [http://starcross33.ifrance.com/lumidee-et-speedy/index.html lumidee et speedy] [http://chasingspaces.ifrance.com/hex-fun6/index.html hex fun6] [http://angeljazz711.ifrance.com/impazzisco-per.html impazzisco per te polisano] [http://risdimpuka.ifrance.com/look-for-book/index.html look for book] [http://alexandraa80.ifrance.com/lydia-pirelli/index.html lydia pirelli] [http://pupsik1993.ifrance.com/lennox-why.html lennox why] [http://listmishyk.ifrance.com/king-of-consequences/index.html king of consequences] [http://chasingspaces.ifrance.com/hajducci/index.html hajducci] [http://cuivenarius.ifrance.com/holiday-inn-republique.html holiday inn republique paris] [http://chasingspaces.ifrance.com/gay/index.html gay] [http://angeljazz711.ifrance.com/immagini-di-incantesimo.html immagini di incantesimo 1] [http://katzella.ifrance.com/harry-potter4/index.html harry potter4] [http://xxxenichkaa.ifrance.com/lamma-meteo.html lamma meteo toscana] [http://child-ofadot.ifrance.com/il-santuario.html il santuario di delphy] [http://katzella.ifrance.com/il-peggio-squillo/index.html il peggio squillo] [http://oddonpurpose.ifrance.com/m-b.html m b] [http://starcross33.ifrance.com/lollipo/index.html lollipo] [http://busjavka.ifrance.com/hombres-nudi/index.html hombres nudi] [http://listmishyk.ifrance.com/karen-dejo/index.html karen dejo] [http://plyuh-vios.ifrance.com/italiane-iraq.html italiane iraq] [http://starcross33.ifrance.com/li-sauli/index.html li sauli] [http://busjavka.ifrance.com/hevaenger/index.html hevaenger] [http://fluffy-mind.ifrance.com/kaoma-s-lambada.html kaoma s lambada] [http://angeljazz711.ifrance.com/il-viaggio-di-un-poeta.html il viaggio di un poeta] [http://taylors-acolyte.ifrance.com/istruzioni-italiano-pdf.html istruzioni italiano pdf fujifilm s2pro] [http://cuivenarius.ifrance.com/hey-ya-outkast.html hey ya outkast testo canzone] [http://thecrownless.ifrance.com/i-don-t-want/index.html i don t want] [http://busjavka.ifrance.com/hestor-y-valentino/index.html hestor y valentino] [http://cuivenarius.ifrance.com/hotelsancandido.html hotelsancandido] [http://child-ofadot.ifrance.com/israel-kamak-over-the.html israel kamak over the rainbow mp3] [http://child-ofadot.ifrance.com/in-tutti-i-mieie.html in tutti i mieie giorni raf] [http://eliasn5gh.ifrance.com/lunar-silver-star.html lunar silver star] [http://risdimpuka.ifrance.com/la-pecora-nera/index.html la pecora nera] [http://risdimpuka.ifrance.com/la-comtaminacion/index.html la comtaminacion del ambiente] [http://oddonpurpose.ifrance.com/l-amico-e-di-baldambembo.html l amico e di baldambembo] [http://oddonpurpose.ifrance.com/la-mia-nemica-amatissima.html la mia nemica amatissima] [http://katzella.ifrance.com/itefonica/index.html itefonica] [http://xxxenichkaa.ifrance.com/le-son-qui-tue.html le son qui tue] [http://pupsik1993.ifrance.com/la-tratoria.html la tratoria] [http://cuivenarius.ifrance.com/horse-latitudes.html horse latitudes] [http://carbonphoenix.ifrance.com/jor-arroyo.html jor arroyo] [http://risdimpuka.ifrance.com/los-brico-midi/index.html los brico midi] [http://listmishyk.ifrance.com/kksjjs/index.html kksjjs] [http://katzella.ifrance.com/hilton-paris/index.html hilton paris] [http://angeljazz711.ifrance.com/i-got-that.html i got that] [http://pupsik1993.ifrance.com/le-pottane.html le pottane] [http://busjavka.ifrance.com/ho-bisogno-di/index.html ho bisogno di te] [http://taylors-acolyte.ifrance.com/i-d-ont-want-you.html i d ont want you back] [http://thecrownless.ifrance.com/isole-tremiti-alberghi/index.html isole tremiti alberghi] [http://xxxenichkaa.ifrance.com/luka-tô-nem.html luka tô nem ai] [http://chasingspaces.ifrance.com/gruppi-hip-hop/index.html gruppi hip hop] [http://oddonpurpose.ifrance.com/la-mia-solitudine.html la mia solitudine] [http://katzella.ifrance.com/il-jazz-americano/index.html il jazz americano] [http://katzella.ifrance.com/hool/index.html hool] [http://alexandraa80.ifrance.com/la-felandina/index.html la felandina] [http://oddonpurpose.ifrance.com/lucilla-di-allmusic.html lucilla di allmusic] [http://child-ofadot.ifrance.com/installazione-gratuita.html installazione gratuita modello unico 200] [http://plyuh-vios.ifrance.com/i-m-the-man-who-murdered.html i m the man who murdered love di xtc] [http://plyuh-vios.ifrance.com/il-destino-cieco-in.html il destino cieco in shopenhauer] [http://eliasn5gh.ifrance.com/la-germania.html la germania] [http://child-ofadot.ifrance.com/inno-curva-b.html inno curva b napoli] [http://taylors-acolyte.ifrance.com/il-quotidiano.html il quotidiano] [http://xxxenichkaa.ifrance.com/lion-sleep-tonight.html lion sleep tonight] [http://carbonphoenix.ifrance.com/jetson-xxx.html jetson xxx] [http://snakeystil.ifrance.com/juliana-paes-playboy/index.html juliana paes playboy] [http://busjavka.ifrance.com/harlem-notturno/index.html harlem notturno] [http://child-ofadot.ifrance.com/iscrizione.html iscrizione] [http://pupsik1993.ifrance.com/legge-sulla-fecondazione.html legge sulla fecondazione assistita] [http://katzella.ifrance.com/hacki-v7/index.html hacki v7] [http://listmishyk.ifrance.com/krmak-papagaj/index.html krmak papagaj] [http://busjavka.ifrance.com/haus/index.html haus] [http://pupsik1993.ifrance.com/luna-nino-porzio.html luna nino porzio] [http://angeljazz711.ifrance.com/il-diritto-di-famiglia.html il diritto di famiglia] [http://risdimpuka.ifrance.com/la-stampa-di/index.html la stampa di torino] [http://eliasn5gh.ifrance.com/liliana-tamberi.html liliana tamberi] [http://busjavka.ifrance.com/hotel-porta-rossa-firenze/index.html hotel porta rossa firenze] [http://cuivenarius.ifrance.com/http-www-xray-2000.html http www xray 2000 co uk] [http://busjavka.ifrance.com/hoobastark/index.html hoobastark] [http://oddonpurpose.ifrance.com/lasat.html lasat] [http://carbonphoenix.ifrance.com/jeux-video-com.html jeux video com] [http://xxxenichkaa.ifrance.com/letra-de-la.html letra de la cancion duele el amor] [http://oddonpurpose.ifrance.com/libertysurf.html libertysurf] [http://taylors-acolyte.ifrance.com/i-cloun.html i cloun] [http://cuivenarius.ifrance.com/heat-is-on.html heat is on] [http://plyuh-vios.ifrance.com/immagini-di-angeli.html immagini di angeli] [http://chasingspaces.ifrance.com/hearns/index.html hearns] [http://child-ofadot.ifrance.com/il-cartone-animato.html il cartone animato del cane balto] [http://thecrownless.ifrance.com/italiane-prigioniere/index.html italiane prigioniere in iraq] [http://oddonpurpose.ifrance.com/life-for-rent.html life for rent] [http://snakeystil.ifrance.com/junior-jack-stupid/index.html junior jack stupid] [http://eliasn5gh.ifrance.com/lorena-mc.html lorena mc] [http://carbonphoenix.ifrance.com/julietas-venegas.html julietas venegas] [http://snakeystil.ifrance.com/ju-jitsu/index.html ju jitsu] [http://eliasn5gh.ifrance.com/la-vita-di-san.html la vita di san francesco] [http://katzella.ifrance.com/hard-sesso-cazzoni/index.html hard sesso cazzoni] [http://fluffy-mind.ifrance.com/katia-gf4.html katia gf4] [http://busjavka.ifrance.com/hotel-olimpia/index.html hotel olimpia] [http://chasingspaces.ifrance.com/htp-www-tettone-it/index.html htp www tettone it] [http://alexandraa80.ifrance.com/lilo-e-stitch/index.html lilo e stitch] [http://chasingspaces.ifrance.com/gratis-porno-non/index.html gratis porno non pagante] [http://chasingspaces.ifrance.com/guida-alla-maturita/index.html guida alla maturita] [http://taylors-acolyte.ifrance.com/il-grande-babumba.html il grande babumba midi] [http://chasingspaces.ifrance.com/guerra-di-spagna/index.html guerra di spagna] [http://plyuh-vios.ifrance.com/i-will-always-love.html i will always love you whitney houston] [http://eliasn5gh.ifrance.com/lord-of-the-boards.html lord of the boards] [http://oddonpurpose.ifrance.com/lupus-tumido.html lupus tumido] [http://angeljazz711.ifrance.com/ingegneria-meccanica.html ingegneria meccanica] [http://thecrownless.ifrance.com/i-watussi/index.html i watussi] [http://risdimpuka.ifrance.com/lotto-ritardi/index.html lotto ritardi] [http://fluffy-mind.ifrance.com/kaczmar.html kaczmar] [http://child-ofadot.ifrance.com/ibs.html ibs] [http://listmishyk.ifrance.com/kelis-rogers/index.html kelis rogers] [http://taylors-acolyte.ifrance.com/io-te-vurria-vasa.html io te vurria vasa] [http://risdimpuka.ifrance.com/la-vida-que-viendra/index.html la vida que viendra] [http://risdimpuka.ifrance.com/lavoro-casa/index.html lavoro casa] [http://starcross33.ifrance.com/lacrimi-de-iubire/index.html lacrimi de iubire] [http://katzella.ifrance.com/il-buono-ilbrutto/index.html il buono ilbrutto ilcattivo] [http://snakeystil.ifrance.com/juanes-a-dios/index.html juanes a dios le pido] [http://chasingspaces.ifrance.com/giochi-gratis/index.html giochi gratis pocket pc] [http://thecrownless.ifrance.com/ipsia-monza/index.html ipsia monza] [http://xxxenichkaa.ifrance.com/lemony-snicket.html lemony snicket] [http://pupsik1993.ifrance.com/leo-vince.html leo vince] [http://cuivenarius.ifrance.com/hit-the-road-jack.html hit the road jack] [http://pupsik1993.ifrance.com/lotta-libera-femminile.html lotta libera femminile] [http://eliasn5gh.ifrance.com/la-disciplina-della.html la disciplina della terra] [http://snakeystil.ifrance.com/julia-tak-na/index.html julia tak na imie mam] [http://thecrownless.ifrance.com/il-dolore-di-ungaretti/index.html il dolore di ungaretti] [http://xxxenichkaa.ifrance.com/lasgo.html lasgo] [http://pupsik1993.ifrance.com/le-olimpiadi.html le olimpiadi] [http://xxxenichkaa.ifrance.com/lena-biolcati.html lena biolcati] [http://alexandraa80.ifrance.com/l-agnese-va-a-morire/index.html l agnese va a morire renata vigano] [http://xxxenichkaa.ifrance.com/libero-it.html libero it] [http://chasingspaces.ifrance.com/gooblle/index.html gooblle] [http://oddonpurpose.ifrance.com/lets-outside-alone.html lets outside alone] [http://angeljazz711.ifrance.com/iraq.html iraq] [http://thecrownless.ifrance.com/io-saro-con-te-di/index.html io saro con te di marco frisina] [http://taylors-acolyte.ifrance.com/il-ballo-del.html il ballo del pio pio] [http://thecrownless.ifrance.com/il-pazzo/index.html il pazzo] [http://oddonpurpose.ifrance.com/linird-skinird.html linird skinird] [http://listmishyk.ifrance.com/katamail-com/index.html katamail com] [http://eliasn5gh.ifrance.com/llucia.html llucia] [http://fluffy-mind.ifrance.com/knokin-on-heaven.html knokin on heaven s door] [http://taylors-acolyte.ifrance.com/i-like-that.html i like that di houston] [http://taylors-acolyte.ifrance.com/incendio.html incendio] [http://listmishyk.ifrance.com/karaokefiles/index.html karaokefiles] [http://plyuh-vios.ifrance.com/incantesimo-con.html incantesimo con walter nudo] [http://xxxenichkaa.ifrance.com/liberatoria-per-video.html liberatoria per video] [http://xxxenichkaa.ifrance.com/leslie-et-j-attends.html leslie et j attends] [http://carbonphoenix.ifrance.com/jfive-modern-time.html jfive modern time] [http://carbonphoenix.ifrance.com/jornal-de-noticias.html jornal de noticias] [http://taylors-acolyte.ifrance.com/il-mondo-insieme.html il mondo insieme a te di max pezzali] [http://katzella.ifrance.com/he-s-a-pirate-midi/index.html he s a pirate midi] [http://alexandraa80.ifrance.com/loredana-bontempi/index.html loredana bontempi] [http://busjavka.ifrance.com/hotels-porto-san/index.html hotels porto san giorgio] [http://snakeystil.ifrance.com/jazda/index.html jazda] [http://plyuh-vios.ifrance.com/inserimento.html inserimento sito] [http://carbonphoenix.ifrance.com/judaspriest.html judaspriest] [http://child-ofadot.ifrance.com/iraq-video-su-web.html iraq video su web mostra ostaggio usa d] [http://taylors-acolyte.ifrance.com/immagini-puttane.html immagini puttane] [http://thecrownless.ifrance.com/i-belive-i-cen-fly/index.html i belive i cen fly] [http://listmishyk.ifrance.com/katesplayground/index.html katesplayground] [http://child-ofadot.ifrance.com/is-it-s-cos-i-m-cool.html is it s cos i m cool] [http://eliasn5gh.ifrance.com/letizia-grande.html letizia grande fratello] [http://chasingspaces.ifrance.com/herlinda-gomez/index.html herlinda gomez] [http://fluffy-mind.ifrance.com/kate-sweetnam.html kate sweetnam] [http://busjavka.ifrance.com/hanno-ucciso/index.html hanno ucciso] [http://taylors-acolyte.ifrance.com/i-mesh.html i mesh] [http://risdimpuka.ifrance.com/landing-gear/index.html landing gear] [http://busjavka.ifrance.com/http-annunci-tiscali/index.html http annunci tiscali it scheda annuncio] [http://child-ofadot.ifrance.com/il-super-uomo.html il super uomo d annunzio] [http://eliasn5gh.ifrance.com/lou-bega-ladies.html lou bega ladies and gentlemen] [http://taylors-acolyte.ifrance.com/il-coccodrillo-come.html il coccodrillo come fa] [http://snakeystil.ifrance.com/jhkj/index.html jhkj] [http://oddonpurpose.ifrance.com/mandi.html mandi] [http://taylors-acolyte.ifrance.com/indeo-codec-per-xp.html indeo codec per xp] [http://angeljazz711.ifrance.com/ingatlah-hari-ini.html ingatlah hari ini] [http://oddonpurpose.ifrance.com/la-mata-del-son.html la mata del son] [http://carbonphoenix.ifrance.com/junio-down.html junio down] [http://cuivenarius.ifrance.com/hit-maia-dance-2004.html hit maia dance 2004] [http://eliasn5gh.ifrance.com/linea-77-66-diabulus.html linea 77 66 diabulus in musica] [http://xxxenichkaa.ifrance.com/laura-pausine.html laura pausine] [http://child-ofadot.ifrance.com/immagini-bonazzi.html immagini bonazzi] [http://taylors-acolyte.ifrance.com/italiano-karaoka.html italiano karaoka] [http://plyuh-vios.ifrance.com/inno-nazionale.html inno nazionale usa] [http://busjavka.ifrance.com/haiducii-sito-ufficiale/index.html haiducii sito ufficiale] [http://eliasn5gh.ifrance.com/like-an-angel.html like an angel] [http://pupsik1993.ifrance.com/li-bero-adsl.html li bero adsl] [http://pupsik1993.ifrance.com/la-palomita.html la palomita] [http://oddonpurpose.ifrance.com/liceodavinci.html liceodavinci] [http://listmishyk.ifrance.com/keys-cabotv/index.html keys cabotv] [http://cuivenarius.ifrance.com/hollywoodjesus-com.html hollywoodjesus com] [http://eliasn5gh.ifrance.com/link-iraq.html link iraq] [http://starcross33.ifrance.com/love-at-fisrt-sight/index.html love at fisrt sight] [http://child-ofadot.ifrance.com/i-believe-my-heart-di.html i believe my heart di duncan james] {{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 02:18, 1 September 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